JavaScript之不可靠的undefined
undefined在 JavaScript 中,假設我們想判斷一個是否是undefined,那么我們通常會這樣寫:
if(a === undefined){//code}
但是,JavaScript 中的undefined并不可靠,我們試著寫這樣一個函數(shù):
function test(a) { var undefined = 1; console.log(undefined); // => 1 if(a===undefined) { // ... } }
可以看到,undefined被輕易地修改為了1,使得我們之后的對于undefined理解引起歧義。所以,在 JavaScript 中,把undefined直接解釋為 “未定義” 是有風險的,因為這個標識符可能被篡改。
在 ES5 之前,全局的undefined也是可以被修改的,而在 ES5 中,該標識符被設計為了只讀標識符, 假如你現(xiàn)在的瀏覽器不是太老,你可以在控制臺中輸入以下語句測試一下:
undefined = 1; console.log(undefined); // => undefined
現(xiàn)在我們能夠明確的,標識符undefined并不能真正反映 “未定義”,所以我們得通過其他手段獲得這一語義。幸好 JavaScript 還提供了void運算符,該運算符會對指定的表達式求值,并返回受信任的undefined:
void expression
最常見的用法是通過以下運算來獲得undefined,表達式為0時的運算開銷最?。?/p>
void 0; // or void(0);
所有需要獲得undefined地方,都通過void 0進行了替代
當然,獲取undefined還有另一種方式:看過jquery源碼的同學,應該知道里面的立即執(zhí)行函數(shù):
(function(window,undefined) { // ... })(window)
在這個函數(shù)中,我們沒有向其傳遞第二參數(shù)(形參名叫undefined),那么第二個參數(shù)的值就會被認為 “未定義”,因此,通過這種方式,在該函數(shù)的作用域中所有的undefined都為受信的undefined。
以上就是JavaScript之不可靠的undefined的詳細內容,更多關于JavaScript之不可靠的undefined的資料請關注腳本之家其它相關文章!
- 處理JavaScript值為undefined的7個小技巧
- JavaScript undefined及null區(qū)別實例解析
- JavaScript中的null和undefined用法解析
- javascript中undefined的本質解析
- JS在Chrome瀏覽器中showModalDialog函數(shù)返回值為undefined的解決方法
- Javascript類型系統(tǒng)之undefined和null淺析
- javascript類型系統(tǒng)——undefined和null全面了解
- Javascript基礎_簡單比較undefined和null 值
- JavaScript必知必會(二) null 和undefined
- 辨析JavaScript中的Undefined類型與null類型
相關文章
JavaScript創(chuàng)建對象的七種經典方式分享
JavaScript 創(chuàng)建對象的方式有很多,通過 Object 構造函數(shù)或對象字面量的方式也可以創(chuàng)建單個對象,顯然這兩種方式會產生大量的重復代碼,并不適合量產。本文介紹了七種非常經典的創(chuàng)建對象的方式,希望對大家有所幫助2022-11-11IE和Firefox在JavaScript應用中的兼容性探討
今天在使用CSS屬性的時候發(fā)現(xiàn)"cursor:hand;"在Firefox中鼠標不會變?yōu)槭中?,后來上網搜索了一下資料,發(fā)現(xiàn)hand這個cursor屬性在Firrefox中不兼容,使用"cursor:pointer"就都可以顯示了。2008-04-04