在JavaScript中,任何合法的函數(shù)都可以作為對(duì)象的構(gòu)造函數(shù),這既包括系統(tǒng)內(nèi)置函數(shù),也包括用戶自己定義的函數(shù)。一旦函數(shù)被作為構(gòu)造函數(shù)執(zhí)行,它內(nèi)部的this屬性將引用函數(shù)本身。
通常來說,構(gòu)造函數(shù)沒有返回值,它們只是初始化由this指針傳遞進(jìn)來的對(duì)象,并且什么也不返回。如果一個(gè)函數(shù)有返回值,被返回的對(duì)象就成了new表達(dá)式的值。從形式上看,一個(gè)函數(shù)被作為構(gòu)造函數(shù)還是普通函數(shù)執(zhí)行的唯一區(qū)別,是否用new運(yùn)算符。
上面的描述事實(shí)上有著更為精確的含義,這要把函數(shù)如果有返回值的情況分為函數(shù)的返回值是引用類型和值類型兩種情況。
如果一個(gè)函數(shù)的返回值是引用類型(數(shù)組,對(duì)象或者函數(shù))的數(shù)據(jù),那么這個(gè)函數(shù)作為構(gòu)造函數(shù)用new運(yùn)算符執(zhí)行構(gòu)造時(shí),運(yùn)算的結(jié)果將被它的返回值取代,這時(shí)候,構(gòu)造函數(shù)體內(nèi)的this值丟失了,取而代之的是被返回的對(duì)象。例如:
代碼如下:
function test()
{
this.a=10;
return function()
{
return 1;
}
}
alert m=new test();
var n=test();
alert(m);//返回return后面的閉包
alert(n);//返回return 后面的閉包
運(yùn)行結(jié)果m的值和n的值是一樣的,都是test函數(shù)返回的閉包,而this引用的對(duì)象和this.a=10的賦值結(jié)果全部被丟棄。
如果一個(gè)函數(shù)的返回值是一個(gè)值類型,那么這個(gè)函數(shù)作為構(gòu)造函數(shù)用new運(yùn)算符執(zhí)行構(gòu)造時(shí),它的返回值將被丟棄。new 表達(dá)式的結(jié)果仍然是this所引用的對(duì)象。
代碼如下:
function test()
{
this.a=10;
return 1;
}
alert m=new test();
var n=test();
alert(m)//返回【Object】
alert(n)//返回1.
更多信息請(qǐng)查看IT技術(shù)專欄