DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 解讀JavaScript代碼 var ie = !-[1,] 最短的IE判定代碼
解讀JavaScript代碼 var ie = !-[1,] 最短的IE判定代碼
編輯:關於JavaScript     
var ie = !-[1,];

    這句代碼在IE9之前曾被稱為世界上最短的IE判定代碼。代碼雖短但確包含了不少javascript基礎知識在裡面。在這個例子中代碼執行時會先調用數組的toString()方法 ,執行[1,].toString()在IE6,7,8中將會得到“1,”。然後表達式就變為!-“1,”。再嘗試把“1,”轉換成數值類型得到NaN ,再對NaN取負得到值仍為NaN。最後執行!NaN返回true。下面通過分解這個語句來回顧下代碼中所涉及到的javascript知識:

浏覽器的數組字面量解析差異

     [1,]表示使用javascript的數組字面量定義了一個數組。 在IE6,7,8中數組有兩個元素,數組中的值分別為1,undefined。在標准的浏覽器中會忽略第一個元素後的undefined,數組只包含一個元素1。

數組的toString()方法

    調用數組對象的toString()方法時會對數組中的每個元素調用toString()方法,如果元素的值為NULL或者undefined時會返回空的字符串,然後將得到的每項的值拼成一個使用 逗號“,”分隔的字符串。

 一元減號運算符  

  使用一元減號運算符時如果運算數是數值類型則直接對運算數取負,否則會先嘗試把運算數轉換為數值類型,轉換過程相當於執行Number函數,然後再對得到的結果取負。 

邏輯非運算

    執行邏輯非運算時如果操作數為NaN、NULL或undefined 時返回 true。

通過上面的知識可以得出代碼 var ie = !-[1,]; 其實等價於 var ie = !(-Number([1,].toString())); 在IE6\7\8中值為true。如分析的有什麼不對的地方或者有什麼不同意見歡迎指正!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved