1 回答

TA貢獻(xiàn)1775條經(jīng)驗(yàn) 獲得超11個(gè)贊
詳細(xì)解釋之前,你必須了解類實(shí)例化的過程中,都經(jīng)歷了什么。
對Function實(shí)例化,F(xiàn)unction相當(dāng)于是構(gòu)造器。
當(dāng)實(shí)例化時(shí),解釋器先生成一個(gè)新的對象(Object),此對象的原型鏈上有一個(gè)constructor屬性,指向這個(gè)構(gòu)造器(Function)本身
將這個(gè)對象作為構(gòu)造器的上下文(this)傳入構(gòu)造器函數(shù)(Function),并執(zhí)行構(gòu)造器函數(shù)
根據(jù)構(gòu)造器函數(shù)最終返回的結(jié)果,如果是對象(Object),則使用返回的對象為實(shí)例化的對象;否則,使用之前構(gòu)造時(shí)的上下文對象(this)作為實(shí)例化的對象
明白了這一點(diǎn)再看第一段代碼。當(dāng) new aFun 時(shí),執(zhí)行 aFun 構(gòu)造器函數(shù),因?yàn)榉祷刂凳?_ 這個(gè)對象,所以以它作為實(shí)例化的結(jié)果。因此,此對象上的 testFun2 方法可以直接調(diào)用,但 testFun 因?yàn)樵?prototype 屬性中,所以無法直接調(diào)用。
第二段代碼使用了閉包。當(dāng)定義完 aFun2 時(shí),aFun2 的結(jié)果就是 _ 這個(gè)函數(shù)。然后對 new aFun2 就相當(dāng)于 new _(只不過作用域不同了)。由于 _ 函數(shù)并沒有返回結(jié)果,所以實(shí)例化的結(jié)果就是以 _ 為構(gòu)造器的對象,而此時(shí) _ 的 prototype 屬性也因?yàn)閷?shí)例化,新對象的原型鏈將指向它。因此,只能調(diào)用原型鏈上的 testFun 方法,卻不能調(diào)用 testFun2 方法。
第一段代碼仍能通過 afun.prototype.testFun(); 調(diào)用;第二段代碼仍能通過 afun2.constructor.testFun2(); 調(diào)用。
添加回答
舉報(bào)