new fn与new fn()有什么区别吗?
参考答案:
用 new 创建构造函数的实例时,通常情况下 new 的构造函数后面需要带括号(譬如:new Parent())。
有些情况下new的构造函数后带括号和不带括号的情况一致,譬如:
js
function Parent(){
this.num = 1;
}
console.log(new Parent());//输出Parent对象:{num:1}
console.log(new Parent);//输出Parent对象:{num:1}但有些情况下new的构造函数后带括号和不带括号的情况并不一致,譬如:
js
function Parent(){
this.num = 1;
}
console.log(new Parent().num);//1
console.log(new Parent.num);//报错结果分析:
从报错信息来看,new Parent.num执行顺序是这样的:先执行Parent.num,此时返回结果为undefined;后执行new,因new后面必须跟构造函数,所以new undefined会报错。
new Parent().num相当于(new Parent()).num,所以结果返回1。
从结果来看,new Parent.num代码相当于new (Parent.num);,new Parent().num相当于(new Parent()).num。由此看来 new 的构造函数后跟括号优先级会提升。
题目要点:
带括号的情况:
new Parent():这是最常见的用法。调用Parent构造函数并返回一个新的Parent实例。new Parent().num:这首先调用Parent构造函数,返回一个Parent实例,然后访问这个实例的num属性。
不带括号的情况:
new Parent:这在大多数情况下是有效的,因为 JavaScript 的解析器会将new Parent视为new (Parent())。也就是说,它首先调用Parent函数(不带参数),然后使用返回的结果作为构造函数来创建新实例。new Parent和new Parent()通常在行为上是一致的,但具体取决于构造函数的实现。
错误用法:
new Parent.num:这是一个错误用法。这里的问题是Parent.num首先被解析,如果Parent上没有num属性,就会返回undefined。然后new操作符尝试使用undefined作为构造函数,这将导致错误。
优先级问题:
new Parent().num和(new Parent()).num是等价的,都是先创建Parent实例,然后访问其num属性。new Parent.num实际上是new (Parent.num),因为Parent.num首先被解析,然后new操作符尝试使用这个结果作为构造函数。