javascript 構(gòu)造函數(shù)強(qiáng)制調(diào)用經(jīng)驗(yàn)總結(jié)
更新時(shí)間:2012年12月02日 10:10:06 作者:
本文將介紹javascript構(gòu)造函數(shù)調(diào)用方面的案例應(yīng)用,需要了解的朋友可以參考下
興致勃勃地定義了下面這么個(gè)構(gòu)造函數(shù):
var Coder = function( nick ){
this.nick = nick;
};
定義構(gòu)造函數(shù)結(jié)束后呢?沒錯(cuò),趕緊實(shí)例化:
var coder = Coder( 'casper' );
這個(gè)coder兄弟叫什么名字?趕緊打印下:
console.log( coder.nick ); //undefined
= =b 竟然是undefined??!再回過頭看看實(shí)例化的那個(gè)語句,不難發(fā)現(xiàn)問題出在哪里:少了個(gè)new
var coder = Coder( 'casper' ); //當(dāng)作普通的函數(shù)來調(diào)用,故內(nèi)部的this指針其實(shí)指向window對(duì)象
console.log( window.nick); //輸出:casper
var coder = new Coder( 'casper' ); //加上new,一切皆不同,this正確地指向了當(dāng)前創(chuàng)建的實(shí)例
console.log( coder.nick ); //輸出:casper
關(guān)于this指針的指向問題不是本文討論的內(nèi)容,可以參考下犀牛書相關(guān)章節(jié)
這樣的錯(cuò)誤貌似挺低級(jí)的,但出現(xiàn)的概率挺高的,腫么去避免或減少這種情況的發(fā)生呢?
可以在內(nèi)部實(shí)現(xiàn)里面動(dòng)下手腳:
var Coder = function( nick ){
if( !(this instanceof Coder) ){
return new Coder( nick );
}
this.nick = nick;
};
其實(shí)很簡(jiǎn)單,實(shí)例化的時(shí)候,內(nèi)部判斷下,當(dāng)前this指向的對(duì)象的類型即可,如果非當(dāng)前構(gòu)造函數(shù)的類型,強(qiáng)制重新調(diào)用一遍構(gòu)造函數(shù)。
突然覺得Coder這名字不夠洋氣?想用Hacker,好吧,我改。。。數(shù)了下,一共有三處要改,這不科學(xué),有沒有辦法只把構(gòu)造函數(shù)的名字改了就行?
當(dāng)然有:
var Coder = function( nick ){
if( !(this instanceof arguments.callee) ){
return new arguments.callee( nick );
}
this.nick = nick;
};
tips:據(jù)說在ES 5的嚴(yán)格模式下面arguments.callee會(huì)被禁用,不過僅當(dāng)ES 5普及同時(shí)你指定了要使用嚴(yán)格模式,否則還是可以用的發(fā)散下思維:在JQ里面包打天下所向披靡的$,大家都知道它會(huì)返回一個(gè)jquery對(duì)象,如下:
var jObject = $('#node_id');
有沒有發(fā)現(xiàn),這里同樣沒有new!應(yīng)該猜到怎么回事了吧。原理是差不多的,不過里面的實(shí)現(xiàn)要復(fù)雜得多,有空再把JQ里面的實(shí)現(xiàn)拔下寫下總結(jié)
復(fù)制代碼 代碼如下:
var Coder = function( nick ){
this.nick = nick;
};
定義構(gòu)造函數(shù)結(jié)束后呢?沒錯(cuò),趕緊實(shí)例化:
var coder = Coder( 'casper' );
這個(gè)coder兄弟叫什么名字?趕緊打印下:
復(fù)制代碼 代碼如下:
console.log( coder.nick ); //undefined
= =b 竟然是undefined??!再回過頭看看實(shí)例化的那個(gè)語句,不難發(fā)現(xiàn)問題出在哪里:少了個(gè)new
var coder = Coder( 'casper' ); //當(dāng)作普通的函數(shù)來調(diào)用,故內(nèi)部的this指針其實(shí)指向window對(duì)象
console.log( window.nick); //輸出:casper
var coder = new Coder( 'casper' ); //加上new,一切皆不同,this正確地指向了當(dāng)前創(chuàng)建的實(shí)例
console.log( coder.nick ); //輸出:casper
關(guān)于this指針的指向問題不是本文討論的內(nèi)容,可以參考下犀牛書相關(guān)章節(jié)
這樣的錯(cuò)誤貌似挺低級(jí)的,但出現(xiàn)的概率挺高的,腫么去避免或減少這種情況的發(fā)生呢?
可以在內(nèi)部實(shí)現(xiàn)里面動(dòng)下手腳:
復(fù)制代碼 代碼如下:
var Coder = function( nick ){
if( !(this instanceof Coder) ){
return new Coder( nick );
}
this.nick = nick;
};
其實(shí)很簡(jiǎn)單,實(shí)例化的時(shí)候,內(nèi)部判斷下,當(dāng)前this指向的對(duì)象的類型即可,如果非當(dāng)前構(gòu)造函數(shù)的類型,強(qiáng)制重新調(diào)用一遍構(gòu)造函數(shù)。
突然覺得Coder這名字不夠洋氣?想用Hacker,好吧,我改。。。數(shù)了下,一共有三處要改,這不科學(xué),有沒有辦法只把構(gòu)造函數(shù)的名字改了就行?
當(dāng)然有:
復(fù)制代碼 代碼如下:
var Coder = function( nick ){
if( !(this instanceof arguments.callee) ){
return new arguments.callee( nick );
}
this.nick = nick;
};
tips:據(jù)說在ES 5的嚴(yán)格模式下面arguments.callee會(huì)被禁用,不過僅當(dāng)ES 5普及同時(shí)你指定了要使用嚴(yán)格模式,否則還是可以用的發(fā)散下思維:在JQ里面包打天下所向披靡的$,大家都知道它會(huì)返回一個(gè)jquery對(duì)象,如下:
var jObject = $('#node_id');
有沒有發(fā)現(xiàn),這里同樣沒有new!應(yīng)該猜到怎么回事了吧。原理是差不多的,不過里面的實(shí)現(xiàn)要復(fù)雜得多,有空再把JQ里面的實(shí)現(xiàn)拔下寫下總結(jié)
您可能感興趣的文章:
- js動(dòng)態(tài)調(diào)用css屬性的小規(guī)律及實(shí)例說明
- JavaScript 錯(cuò)誤處理與調(diào)試經(jīng)驗(yàn)總結(jié)
- js下關(guān)于onmouseout、事件冒泡的問題經(jīng)驗(yàn)小結(jié)
- 寫給想學(xué)習(xí)Javascript的朋友一點(diǎn)學(xué)習(xí)經(jīng)驗(yàn)小結(jié)
- javascript 操作select下拉列表框的一點(diǎn)小經(jīng)驗(yàn)
- JS前端框架關(guān)于重構(gòu)的失敗經(jīng)驗(yàn)分享
- JS效率個(gè)人經(jīng)驗(yàn)談(8-15更新),加入range技巧
- javascript 框架小結(jié) 個(gè)人工作經(jīng)驗(yàn)
- jquery.validate.js插件使用經(jīng)驗(yàn)記錄
- Javascript 多瀏覽器兼容總結(jié)(實(shí)戰(zhàn)經(jīng)驗(yàn))
- 使用node.js半年來總結(jié)的 10 條經(jīng)驗(yàn)
- 【經(jīng)驗(yàn)總結(jié)】編寫JavaScript代碼時(shí)應(yīng)遵循的14條規(guī)律
相關(guān)文章
JavaScript實(shí)現(xiàn)簡(jiǎn)單的tab選項(xiàng)卡切換
這篇文章主要介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單的tab選項(xiàng)卡切換的相關(guān)資料,需要的朋友可以參考下2016-01-01TypeScript中的interface與type實(shí)戰(zhàn)
這篇文章主要介紹了TypeScript中的interface與type詳解,它們都是用來定義類型的強(qiáng)大工具,在實(shí)際開發(fā)中,你可以根據(jù)具體情況選擇使用 interface 或 type,或者甚至將它們結(jié)合起來使用,需要的朋友可以參考下2023-06-06JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例
這篇文章主要介紹了JavaScript代碼模擬鼠標(biāo)自動(dòng)點(diǎn)擊事件示例,文章通過示例代碼和運(yùn)行效果圖介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-0880行代碼寫一個(gè)Webpack插件并發(fā)布到npm
最近在學(xué)習(xí) Webpack 相關(guān)的原理,本文用80行代碼寫一個(gè)Webpack插件并發(fā)布到npm,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05微信小程序?qū)崿F(xiàn)購(gòu)物車選擇規(guī)格顏色效果
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)購(gòu)物車選擇規(guī)格顏色選中效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01javascript監(jiān)聽頁面刷新和頁面關(guān)閉事件方法詳解
本文主要介紹了javascript監(jiān)聽頁面刷新和頁面關(guān)閉事件的方法,具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01Javascript學(xué)習(xí)筆記-詳解in運(yùn)算符
in運(yùn)算符是javascript語言中比較特殊的一個(gè),可以單獨(dú)使用作為判斷運(yùn)算符,也常被用于for...in循環(huán)中遍歷對(duì)象屬性2011-09-09three.js實(shí)現(xiàn)圍繞某物體旋轉(zhuǎn)
本篇文章主要介紹了three.js實(shí)現(xiàn)圍繞某物體旋轉(zhuǎn)的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01