论坛首页 Web前端技术论坛

JavaScript中点号“.”的多义性

浏览 2180 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2014-06-07  

点号「.」在JavaScript中有两种语义

语义1、表示算术中的小数点(浮点数),如 2.5

语义2、取对象属性、方法,如 [].push(2)

 

这几乎没有任何难理解的地方,但下面这个问题则很有趣。

// 这行代码会如何执行
1.toString();

Firebug 中如下

这里的点号表达的是上述的语义1,因此点号后面必须跟一个数字,这里跟的是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。

 

相关:

Javascript中大括号“{}”的多义性

Javascript中中括号“[]”的多义性

Javascript小括号“()”的多义性

http://bonsaiden.github.io/JavaScript-Garden/

 

  • 大小: 14.4 KB
   发表时间:2014-06-23  
赞。。有趣
0 请登录后投票
   发表时间:2014-06-27  
试了下,的确是。
蛮有意思,以前都没有注意过。
这个也可以
1. .toString();
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics