建站学 - 轻松建站从此开始!

建站学-个人建站指南,网页制作,网站设计,网站制作教程

定义对象或数组直接量时各浏览器对多余逗号的处理

时间:2011-03-02 09:42来源: 作者:Snandy 点击:
定义对象或数组直接量时不同浏览器引擎对多余逗号的处理: js报错分为两种:语法错误和运行错误 1、js引擎在代码载入时进行语法分析,如果js写的不规范则语法分析通不过。这时候的错误称为语法错误 2、语法分析通过了,js引擎会执行代码。执行期间发生的错误称为运
定义对象或数组直接量时不同浏览器引擎对多余逗号的处理:
js报错分为两种:语法错误和运行错误

1、js引擎在代码载入时进行语法分析,如果js写的不规范则语法分析通不过。这时候的错误称为语法错误
2、语法分析通过了,js引擎会执行代码。执行期间发生的错误称为运行错误

不同引擎处理这2种错误的提示不太一样。如下:
view sourceprint?
1    var p = {name:"Jack",age:33,};//注意33后有个逗号
2        p.toString = function() {return "姓名:" +this.name + ",年龄:" + this.age};
3    console.log(p);
4    alert(p);//姓名:Jack,年龄33<br>

firefox下测试,引擎会忽略33后的逗号,可以通过语法检查,在执行期也不会报错
IE6/7下测试,语法分析期就报错了,当然也不会进入执行期了。
不过在IE8下已经修复此问题,不会报错了。其它浏览器也不会报错。

总结下:此错误很难发现,经常是不小心就加了个逗号,或者定义了一个很多属性的对象或数组后来又要删除其中的某些而不小心留下了多余的逗号。
view sourceprint?
1    //不规范的写法
2    var p = {name:"Jack",age:33,};
3    var ary = ["one","two","three",];
4    //规范的写法
5    var p = {name:"Jack",age:33};
6    var ary = ["one","two","three"];

此外,定义数组直接量时也可能碰到这个问题,如数组最后多了个逗号
view sourceprint?
1    var ary = [1,2,];
2    console.log(ary.length);

IE6/7/8 输出length为3,IE9及其它浏览器为2。ECMAScript 5 11.1.4 其中有段说明了应该忽略最后的逗号。但直到IE9才实现该规范。其它浏览器则没问题。

ECMAScript 5 11.1.4 写道:

Array elements may be elided at the beginning, middle or end of the element list. Whenever a comma in the element list is not preceded by an AssignmentExpression (i.e., a comma at the beginning or after another comma), the missing array element contributes to the length of the Array and increases the index of subsequent elements. Elided array elements are not defined. If an element is elided at the end of an array, that element does not contribute to the length of the Array.

有人曾经利用了数组的这个特性创造出了所谓《全世界最短的IE判断》
view sourceprint?
1    var ie = !-[1,];
2    alert(ie);

但在IE9下被终止了。不要利用这个Bug去判断浏览器。 (责任编辑:admin)
织梦二维码生成器
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片