如何在node.js中使用new运算符?

Pav*_*ský 13 require new-operator node.js

我们有一个带有以下代码的file.js:

module.exports.func = function(txt) {
    this.a = 1;
    this.b = 2;
    console.log(txt, this);
    return this;
}
Run Code Online (Sandbox Code Playgroud)

现在我们有另一个JS文件,我们做以下事情:

var r1 = new (require('./file')).func('r1');
var r2 = new require('./file').func('r2');
Run Code Online (Sandbox Code Playgroud)

在r1的情况下,它按预期工作 - r1包含对新创建的对象的引用.

在r2的情况下,它不起作用 - r2从file.js中获取对module.exports的引用.

目的是通过调用func()构造函数来创建一个新对象.当然,我也可以这样做,它等于r1:

var r3 = require('./file');
var r4 = new r3.func('r1');
Run Code Online (Sandbox Code Playgroud)

但是,我不明白为什么r2的行为与r1的行为不同.

周围的额外括号('./ file')如何产生影响?

Ben*_*aum 25

这两个版本根本不同.

这个:

new (require('./file')).func('r1');
Run Code Online (Sandbox Code Playgroud)

执行require,返回导出,./file然后在结果上调用new运算符.

这个:

var r2 = new require('./file').func('r2');
Run Code Online (Sandbox Code Playgroud)

Invokes require作为构造函数.


让我们看一个更加孤立和简单的例子:

new Date() // creates a new date object
new (Date()) // throws a TypeError: string is not a function
Run Code Online (Sandbox Code Playgroud)

  • @PavelLobodinský如果有疑问,只有一个地方可以检查:) [规范](http://es5.github.io/#x11.2.2)告诉我们它调用[[[Construct]]内部方法]( http://es5.github.io/#x13.2.2)设置原型并运行`this`作为新对象.当不是"new NewExpression"(或带参数)的形式时,我们就不是这种情况.包含在`()`中,这被解释为调用`[```的`[[Call]]`内部方法(用简单的英语调用它).然后我们留下了一个新的NewExpression`,它被评估为新的运算符:) (2认同)