解讀JavaScript代碼 var ie = !-[1,] 最短的IE判定代碼
這句代碼在IE9之前曾被稱為世界上最短的IE判定代碼。代碼雖短但確包含了不少javascript基礎知識在里面。在這個例子中代碼執(zhí)行時會先調用數(shù)組的toString()方法 ,執(zhí)行[1,].toString()在IE6,7,8中將會得到“1,”。然后表達式就變?yōu)?/SPAN>!-“1,”。再嘗試把“1,”轉換成數(shù)值類型得到NaN ,再對NaN取負得到值仍為NaN。最后執(zhí)行!NaN返回true。下面通過分解這個語句來回顧下代碼中所涉及到的javascript知識:
瀏覽器的數(shù)組字面量解析差異
[1,]表示使用javascript的數(shù)組字面量定義了一個數(shù)組。 在IE6,7,8中數(shù)組有兩個元素,數(shù)組中的值分別為1,undefined。在標準的瀏覽器中會忽略第一個元素后的undefined,數(shù)組只包含一個元素1。
數(shù)組的toString()方法
調用數(shù)組對象的toString()方法時會對數(shù)組中的每個元素調用toString()方法,如果元素的值為NULL或者undefined時會返回空的字符串,然后將得到的每項的值拼成一個使用 逗號“,”分隔的字符串。
一元減號運算符
使用一元減號運算符時如果運算數(shù)是數(shù)值類型則直接對運算數(shù)取負,否則會先嘗試把運算數(shù)轉換為數(shù)值類型,轉換過程相當于執(zhí)行Number函數(shù),然后再對得到的結果取負。
邏輯非運算
執(zhí)行邏輯非運算時如果操作數(shù)為NaN、NULL或undefined 時返回 true。
通過上面的知識可以得出代碼 var ie = !-[1,]; 其實等價于 var ie = !(-Number([1,].toString())); 在IE6\7\8中值為true。如分析的有什么不對的地方或者有什么不同意見歡迎指正!
- JScript中的''var''定義變量的作用域
- Javascript中的var_dump函數(shù)實現(xiàn)代碼
- var與Javascript變量隱式聲明
- Javascript var變量隱式聲明方法
- js for循環(huán),為什么一定要加var定義i變量
- 關于JavaScript中var聲明變量作用域的推斷
- 在Javascript中 聲明時用"var"與不用"var"的區(qū)別
- JavaScript var聲明變量背后的原理示例解析
- javascript定義變量時有var和沒有var的區(qū)別探討
- JavaScript中var關鍵字的使用詳解
- javascript中加var和不加var的區(qū)別 你真的懂嗎
相關文章
javascript和jquery實現(xiàn)設置和移除文本框默認值效果代碼
這篇文章主要介紹了javascript和jquery實現(xiàn)設置和移除文本框默認值效果代碼,本文實現(xiàn)的是類似html5 placeholder(空白提示)一種效果,需要的朋友可以參考下2015-01-01JavaScript實現(xiàn)仿淘寶商品購買數(shù)量的增減效果
最近接了個項目,要開發(fā)一個地方的O2O租書項目,使用的是asp.net mvc技術,其中咋圖書詳情頁,用戶可以輸入借閱的數(shù)量,器實現(xiàn)此功能的方法是使用了js來控制數(shù)量的增減和校驗,對js實現(xiàn)商品數(shù)量的增減功能感興趣的朋友一起學習吧2016-01-01JavaScript實現(xiàn)簡單的隱藏式側邊欄功能示例
這篇文章主要介紹了JavaScript實現(xiàn)簡單的隱藏式側邊欄功能,涉及javascript結合定時器針對頁面元素屬性動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下2018-08-08