寫(xiě)出更好的JavaScript之undefined篇(上)
我們寫(xiě)JavaScript程序的時(shí)候總有需要用到“未定義”的時(shí)候,比方說(shuō)我們要知道某一個(gè)值是不是已經(jīng)經(jīng)過(guò)賦值,或者我們希望消除某一個(gè)已經(jīng)賦予的值,我們就可能這樣做:
output(myVar === undefined);
myVar = undefined;
然而這樣做并不太好,如果我們嘗試“讀”(或者比較)一個(gè)不存在的變量,就會(huì)引發(fā)一個(gè)異常。
比方說(shuō)如果因?yàn)樵O(shè)計(jì)得不夠周全,執(zhí)行上面的代碼的時(shí)候還沒(méi)有定義過(guò)myVar這個(gè)變量,上面的代碼就會(huì)出錯(cuò);
另外在較早的瀏覽器版本上,也不存在undefined這個(gè)預(yù)定義值,所以為了提高兼容性和容錯(cuò)性,我們可以這樣做:
output(typeof(myVar) == "undefined");
myVar = void(0);
typeof運(yùn)算符是JavaScript的語(yǔ)言功能,雖然上面的代碼看起來(lái)像是這樣的一種東西:
output(oneFunction(myVar) == "undefined");
myVar = void(0);
但這兩者有一個(gè)重要區(qū)別——當(dāng)myVar不存在的時(shí)候,前者可以正確執(zhí)行,并返回字符串"undefined";而后者不管內(nèi)部構(gòu)造是什么樣的,都會(huì)引發(fā)異常。
void則是另一個(gè)語(yǔ)言功能,這個(gè)運(yùn)算符的意義是向腳本的其它部分隱藏它的傳入?yún)?shù);而假如有一個(gè)語(yǔ)句試圖得到void“運(yùn)算”的結(jié)果,它就只能得到“未定義”。
因?yàn)関oid的這個(gè)特性,void最常見(jiàn)的功能就有兩種:一是像上面的代碼中那樣將“未定義”值賦予給其它變量/屬性;另一種就是像下面這樣:
<a href="javascript:void(favList.push(curItem));">添加到收藏列表</a>
其中favList是一個(gè)JavaScript數(shù)組,而curItem是一個(gè)已經(jīng)定義的對(duì)象——數(shù)組的push方法會(huì)返回執(zhí)行push操作以后數(shù)組的長(zhǎng)度,在這個(gè)例子里面這個(gè)長(zhǎng)度對(duì)我們來(lái)說(shuō)一點(diǎn)用都沒(méi)有,但如果放任它不管的話,瀏覽器就可能會(huì)跳轉(zhuǎn)到一個(gè)幾乎為空白的腳本結(jié)果頁(yè)面,只顯示push的返回值,比方說(shuō)“3”。
因此需要用一個(gè)void運(yùn)算符來(lái)“欺騙”瀏覽器:這里啥都沒(méi)有。
現(xiàn)在把目光回到對(duì)“未定義”的使用上,就會(huì)發(fā)現(xiàn)前面我們用來(lái)同“未定義”比較的“高容錯(cuò)性”的typeof運(yùn)算符,用起來(lái)有點(diǎn)麻煩:總共需要多寫(xiě)“typeof()""”這樣10個(gè)字符。
雖然我們是成天跟麻煩打交道的程序員,但這也不能說(shuō)明我們不該想辦法減少麻煩啊~各種開(kāi)發(fā)工具其實(shí)不都是為了把編程工作變得簡(jiǎn)單才出現(xiàn)的么?
所以說(shuō)如果明確知道一個(gè)變量一定一定絕對(duì)絕對(duì)已經(jīng)聲明過(guò),就可以把這個(gè)變量直接和已知的“未定義”相比較,比方說(shuō)這樣:
output(myVar === void(0));
相比于使用typeof運(yùn)算符,后面這個(gè)辦法除了少打幾個(gè)字符,還有一些好處:可以避免難以察覺(jué)的拼寫(xiě)錯(cuò)誤(比方說(shuō)把“undefined”寫(xiě)成“undefinied”什么的) 。
到這里,最常見(jiàn)的關(guān)于“undefined”/“未定義”的技巧,已經(jīng)介紹完了。
在下一篇里面,我會(huì)介紹另一些不太常見(jiàn)的技巧。
相關(guān)文章
JavaScript 獲取元素在父節(jié)點(diǎn)中的下標(biāo)(推薦)
jQuery中直接通過(guò)$(this).index()即可得到當(dāng)前元素的下標(biāo)。下面通過(guò)實(shí)例給大家介紹JavaScript 獲取元素在父節(jié)點(diǎn)中的下標(biāo),需要的朋友參考下吧2017-06-06用javascript實(shí)現(xiàn)倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了用javascript實(shí)現(xiàn)倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-02-02javascript里絕對(duì)用的上的字符分割函數(shù)總結(jié)
本節(jié)主要介紹了javascript里比較實(shí)用的字符分割函數(shù)的使用,需要的朋友可以參考下2014-07-07JavaScript如何實(shí)現(xiàn)數(shù)組按屬性分組
在JavaScript中,有多種方法可以對(duì)數(shù)組按屬性進(jìn)行分組,這篇文章主要為大家至少介紹了6種常見(jiàn)的方法,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-08-08JavaScript 特有方法計(jì)算二進(jìn)制中1的個(gè)數(shù) split方法
這是一道網(wǎng)上看到的前端的筆試題,主要思想是利用JavaScript的toString方法將十進(jìn)制數(shù)轉(zhuǎn)換為二進(jìn)制的字符串。然后for循環(huán)遍歷計(jì)算字符串中”1″出現(xiàn)的次數(shù)。2010-05-05JS中驗(yàn)證整數(shù)和小數(shù)的正則表達(dá)式
網(wǎng)上很多關(guān)于驗(yàn)證小數(shù)的正則表達(dá)式,但是很多都不是百分百正確,所以我結(jié)合一些前輩的經(jīng)驗(yàn),寫(xiě)了一個(gè),分享到腳本之家平臺(tái),對(duì)小數(shù)或整數(shù)正則表達(dá)式的相關(guān)知識(shí)感興趣的朋友一起看看吧2018-10-10關(guān)于加快微信小程序開(kāi)發(fā)的一些小建議
微信小程序是一種全新的連接用戶與服務(wù)的方式,下面這篇文章主要給大家介紹了關(guān)于加快微信小程序開(kāi)發(fā)的一些小建議,需要的朋友可以參考下2021-05-05Javascript頁(yè)面跳轉(zhuǎn)常見(jiàn)實(shí)現(xiàn)方式匯總
這篇文章主要介紹了Javascript頁(yè)面跳轉(zhuǎn)常見(jiàn)實(shí)現(xiàn)方式,結(jié)合實(shí)例匯總分析了JavaScript常用的七種頁(yè)面跳轉(zhuǎn)實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11