解析JavaScript中點號“.”的多義性
更新時間:2013年12月02日 10:10:39 作者:
這篇文章主要介紹了JavaScript中點號“.”的多義性。需要的朋友可以過來參考下,希望對大家有所幫助
點號「.」在JavaScript中有兩種語義
語義1、表示算術中的小數(shù)點(浮點數(shù)),如 2.5
語義2、取對象屬性、方法,如 [].push(2)
這幾乎沒有任何難理解的地方,但下面這個問題則很有趣。
復制代碼 代碼如下:
// 這行代碼會如何執(zhí)行
1.toString();
Firebug 中如下

這里的點號表達的是上述的語義1,因此點號后面必須跟一個數(shù)字,這里跟的是toString,報語法錯了。
解決方法很簡單,如加個小括號
復制代碼 代碼如下:
(1).toString();
還可以這么寫,但難理解些
復制代碼 代碼如下:
1..toString();
之所以瀏覽器中都能運行,是因為各瀏覽器JS引擎都把“1..toString()”理解成了 “1.0.toString()”。這里第一個點號是語義1,第二個點號是語義2。
還有更奇怪的寫法,竟然也沒有報錯
復制代碼 代碼如下:
1 .toString(); // 注意點號前面有一個空格
顯然,這里的點號是語義2,即JS引擎會忽略點運算符前邊的空格,其實無論前后的空格都會忽略。如下
復制代碼 代碼如下:
1 . toString(); // 點號前后都有一個空格
1 . toString(); // 點號前后各有兩個空格
1 .toString(); // 點號前有一個tab
1 . toString(); // 點號前后各有一個tab
JS引擎不但會忽略空格,也會忽略tab。
相關文章
詳解JS中的堆棧,事件循環(huán),執(zhí)行上下文和作用域以及閉包
這篇文章主要為大家詳細介紹了JavaScript中的堆棧,事件循環(huán),執(zhí)行上下文和作用域以及閉包的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以了解下2024-01-01JavaScript flash復制庫類 Zero Clipboard
開發(fā)中經(jīng)常會用到復制的功能,在 IE 下實現(xiàn)比較簡單。但要想做到跨瀏覽器比較困難了。2011-01-01