您现在的位置: 万盛学电脑网 >> 程序编程 >> 脚本专题 >> javascript >> 正文

解析JavaScript中点号“.”的多义性

作者:佚名    责任编辑:admin    更新时间:2022-06-22

 这篇文章主要介绍了JavaScript中点号“.”的多义性。需要的朋友可以过来参考下,希望对大家有所帮助

点号「.」在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。