天天看點

構造函數中return 不同類型的值(對象或非對象)

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

js