当前位置: 代码迷 >> Web前端 >> 对象无length属性时IE6/7中没法将其转换成伪数组(ArrayLike)
  详细解决方案

对象无length属性时IE6/7中没法将其转换成伪数组(ArrayLike)

热度:196   发布时间:2012-09-01 09:33:03.0
对象无length属性时IE6/7中无法将其转换成伪数组(ArrayLike)

有时需要将数组转成伪数组(ArrayLike),如下

var ary = ['one','two','three'];
var obj = {}; // 没有length属性
Array.prototype.push.apply(obj, ary);
for(var i in obj){
	alert(i + ': ' + obj[i]);
}

?

IE8/9/Firefox/Safari/Chrome 依次弹出了obj的key及其value。即能转换成ArrayLike。

IE6/7 下则不能,没有输出任何信息表明obj仍然是个空对象。

?

如果给obj加个length属性,情况则不同

var ary = ['one','two','three'];
var obj = {length:0}; // 有length,值为0
Array.prototype.push.apply(obj, ary);
for(var i in obj){
	alert(i + ': ' + obj[i]);
}

?

这次IE6/7(所有浏览器 )中均弹出了key及其value,都能转换成ArrayLike

?

注意,length只能赋值为0而非它值,否则得到的对象key和value就不是一一对应的了。

var ary = ['one','two','three'];
var obj = {length:2}; // 有length,非零值
Array.prototype.push.apply(obj, ary);
for(var i in obj){
	alert(i + ': ' + obj[i]);
}

?

相关:

将HTMLCollection/NodeList/伪数组转换成数组

  相关解决方案