function F1() {
this.name= 'zhangsan';
return [];
}
var f1=new F1();
console.log(f1);//[]
console.log(f1.name);//undefined
function F2() {
this.age = ;
return ;
}
var f2=new F2();
console.log(f2);//F2{name:'zhangsan'}
console.log(f2.name);//'zhangsan'
会出现上面这种情况的原因如下:
根据ECMAScript标准的规则,如果是在构造函数中,当回传值(return)是个对象时,用new之后就是得到那个return的对象。当回传值是对象以外的,如number、string、boolean或null、undefined(没有return)时,就会回传新构造出来的实例对象。