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