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)時,就會回傳新構造出來的執行個體對象。