nev*_*ame 116 javascript global-variables node.js
这是2个文件:
// main.js
require('./modules');
console.log(name); // prints "foobar"
// module.js
name = "foobar";
当我没有"var"时,它可以工作.但是当我有:
// module.js
var name = "foobar";
名称将在main.js中未定义.
我听说全局变量很糟糕,你最好在引用之前使用"var".但这是全球变量好的情况吗?
jma*_*777 170
全局变量几乎从来都不是一件好事(也许是一两个例外......).在这种情况下,看起来你真的只想导出你的"名称"变量.例如,
// module.js
var name = "foobar";
// export it
exports.name = name;
然后,在main.js ...
//main.js
// get a reference to your required module
var myModule = require('./module');
// name is a member of myModule due to the export above
var name = myModule.name;
Fel*_*ira 28
我无法找到一个全局var是最佳选择的场景,当然你可以有一个,但看看这些例子你可能会找到一个更好的方法来实现同样的目标:
您需要一些在整个应用程序中相同的值,但它会根据环境(生产,开发或测试)而变化,例如邮件类型,您需要:
// File: config/environments/production.json
{
    "mailerType": "SMTP",
    "mailerConfig": {
      "service": "Gmail",
      ....
}
和
// File: config/environments/test.json
{
    "mailerType": "Stub",
    "mailerConfig": {
      "error": false
    }
}
(也为dev做一个类似的配置)
要确定要加载哪个配置,请创建一个主配置文件(这将在整个应用程序中使用)
// File: config/config.js
var _ = require('underscore');
module.exports = _.extend(
    require(__dirname + '/../config/environments/' + process.env.NODE_ENV + '.json') || {});
而现在,你可以得到的数据是这样的:
// File: server.js
...
var config = require('./config/config');
...
mailer.setTransport(nodemailer.createTransport(config.mailerType, config.mailerConfig));
// File: constants.js
module.exports = {
  appName: 'My neat app',
  currentAPIVersion: 3
};
并以这种方式使用它
// File: config/routes.js
var constants = require('../constants');
module.exports = function(app, passport, auth) {
  var apiroot = '/api/v' + constants.currentAPIVersion;
...
  app.post(apiroot + '/users', users.create);
...
不是这个的忠实粉丝,但至少你可以跟踪"名称"的使用(引用OP的例子)并进行验证.
// File: helpers/nameHelper.js
var _name = 'I shall not be null'
exports.getName = function() {
  return _name;
};
exports.setName = function(name) {
  //validate the name...
  _name = name;
};
并使用它
// File: controllers/users.js
var nameHelper = require('../helpers/nameHelper.js');
exports.create = function(req, res, next) {
  var user = new User();
  user.name = req.body.name || nameHelper.getName();
  ...
当没有其他解决方案而不是全局时var,可能会有一个用例,但通常您可以使用其中一种方案在应用程序中共享数据,如果您开始使用node.js(就像我之前的某个时候)尝试组织你在那里处理数据的方式,因为它可以很快变得混乱.
Vin*_*ran 13
如果我们需要共享多个变量,请使用以下格式
//module.js
   let name='foobar';
   let city='xyz';
   let company='companyName';
   module.exports={
    name,
    city,
    company
  }
用法
  // main.js
    require('./modules');
    console.log(name); // print 'foobar'
更新资料
将任何要共享的变量保存为一个对象。然后将其传递给已加载的模块,以便它可以通过对象引用访问变量。
// myModule.js
var shared = null;
function init(obj){
    shared = obj;
}
module.exports = {
    init:init
}
。
// main.js
var myModule = require('./myModule.js');
var shares = {value:123};
myModule.init(shares);
旧答案
要在模块之间共享变量,您可以使用function获取主模块和模块之间的变量值。
//myModule.js
var mainFunction = null; //You can also put function reference in a Object or Array
function functionProxy(func){
    mainFunction = func; //Save the function reference
}
// --- Usage ---
// setTimeout(function(){
//   console.log(mainFunction('myString'));
//   console.log(mainFunction('myNumber'));
// }, 3000);
module.exports = {
    functionProxy:functionProxy
}
。
//main.js
var myModule = require('./myModule.js');
var myString = "heyy";
var myNumber = 12345;
function internalVariable(select){
    if(select=='myString') return myString;
    else if(select=='myNumber') return myNumber;
    else return null;
}
myModule.functionProxy(internalVariable);
// --- If you like to be able to set the variable too ---
// function internalVariable(select, set){
//    if(select=='myString'){
//        if(set!=undefined) myString = set;
//        else return myString;
//    }
//    else if(select=='myNumber'){
//      if(set!=undefined) myNumber = set;
//      else return myNumber;
//    }
//    else return null;
// }
main.js即使更改了值,也始终可以获取值。
| 归档时间: | 
 | 
| 查看次数: | 160154 次 | 
| 最近记录: |