2

我试图让全局变量在 node.js 中工作,但似乎我并不真正理解这个概念,即使我的理解与文档相匹配。

最小的例子

我使用汇总编译的main.js文件是:

global.a = 1;
require('./core/test.js');

我的core/test.js文件很简单:

console.log(a);

这会导致错误:

未捕获的 ReferenceError: a 未定义

完全编译的输出是:

(function (exports) {
'use strict';

var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};

console.log(a);

commonjsGlobal.a = 1;

}((this.LaravelElixirBundle = this.LaravelElixirBundle || {})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjpudWxsLCJzb3VyY2VzIjpbIkM6L3dhbXAvd3d3L3V1YmMvcmVzb3VyY2VzL2Fzc2V0cy9qcy9jb3JlL3Rlc3QuanMiLCJDOi93YW1wL3d3dy91dWJjL3Jlc291cmNlcy9hc3NldHMvanMvYXBwLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnNvbGUubG9nKGEpO1xyXG4iLCJnbG9iYWwuYSA9IDE7XHJcbnJlcXVpcmUoJy4vY29yZS90ZXN0LmpzJyk7XHJcbiJdLCJuYW1lcyI6WyJnbG9iYWwiXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQzs7QUNBZkEsY0FBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7OyJ9

似乎. a_ 我不是 100% 确定这在 JS 中是否重要,但它可能会导致错误。 console.log(a);

所以我的问题是:是什么原因造成的,我在这里做错了什么?

可能相关信息:我正在使用 Laravel Elixir 编译所有内容。

注意:请不要发布关于是否在 node.js 或一般情况下使用全局变量的讨论。我知道这通常是个坏主意,但在这种情况下我有充分的理由这样做。

编辑:附加上下文

我真正想做的是让 Zurb Foundation 通过 node.js 与 Laravel Elixir 一起工作。我是foundation-sites通过 NPM 安装的。foundation-sites依赖jquery,它自己拉。但是,Foundation 似乎并没有遵循通常的惯例,即var jquery = require('jquery');在自己的 js 文件中使用类似的东西。它实际上依赖于jQuery可用的全局变量。因此,我必须以某种方式确保这一点。

我的实际文件如下所示:

global.jQuery = global.$ = require('jquery');
require('foundation-sites');

因此,如果有任何 Foundation/Laravel 特定的答案,我也会很高兴听到它们。有什么我没有得到的,还是基金会没有以“正确”的方式创建他们的包?

4

4 回答 4

4

在我看来,您的捆绑程序存在问题,不尊重您在其中执行这两行的顺序。您的来源显然是:

global.a = 1;
require('./core/test.js');

...但捆绑的结果显然是相反的:

console.log(a);
commonjsGlobal.a = 1;

似乎它正在提升require电话。一般来说,require需要在执行控制流中的特定点进行调用并不是最佳实践(实际上,在为 ES2015 定义模块时,import明确定义为不在模块的分步控制流中执行)。

因此,如果您需要这样做,您可能需要查看另一个捆绑程序。但请检查它是否支持依赖解析顺序以外的顺序。

于 2017-01-05T16:01:47.217 回答
3

你是对的,它应该工作。这是一个工作示例:

// file1.js
global.a = 'hello';
require('./file2');

// file2.js
console.log(a);

运行node file1.js,你会看到'hello'打印到控制台。

看起来您正在使用其他一些工具(Laravel / Elixir)。直接使用node,看看会发生什么。

于 2017-01-05T15:52:20.717 回答
0

我通过提供一个设置所需变量的方法解决了这个问题。output.intro在您的情况下,这将是:

// rollup.config.js
export default {
  // ...
  output: {
    // ...
    intro: `let a = 1;`
  }
};

诚然,这符合 hack 的条件,但在我的情况下解决了捆绑问题(从 rollup 切换不是一种选择)。

于 2019-07-03T08:44:46.053 回答
0

好吧,我通过使用browserify而不是rollup. 感谢其他答案为我指明了正确的方向。这不是一个完美的解决方案,我仍然不完全理解两者之间的区别,但它会为这个项目做。

我的 gulpfile 的相关部分:

mix.browserify('app.js','public/js/app.js');

为了browserify与 Laravel Elixir 一起使用,我使用了

npm install laravel-elixir-browserify-official --save-dev
于 2017-01-05T18:59:46.817 回答