我有点混淆了JavaScript中的新关键字。以下面的例子为例
function A (value) {
this.a = value;
}
function B (value) {
return new A (value);
}
console.log ( B (0)); // { a: 0 }
console.log (new B (0)); // { a: 0 }我希望能够创建"A“的新实例,而不必使用" new”。为此,我有" B()“,但是,当我调用"new ()”时,它似乎做了与“B()”相同的事情,好像忽略了"new“。在这两种情况下,实例等于"A“。到底是怎么回事?
发布于 2015-07-23 13:33:27
来自new
构造函数返回的对象将成为整个新表达式的结果。如果构造函数没有显式返回对象,则使用步骤1中创建的对象。(通常构造函数不返回值,但如果要重写正常的对象创建过程,则可以选择返回。)
这个摘录告诉你
new B所做的不是“正常的”(只是没有理由这么做)B明确返回的值也由new B返回。如果坚持new的正常使用,您不会感到困惑:传递给它一个普通的构造函数,它是一个函数,它不返回任何内容,只是简单地初始化它的上下文(this)。
https://stackoverflow.com/questions/31588874
复制相似问题