将类数组转换成一个真正有意义的数组Array.prototype.slice.call(argument)

var box=document.getElementById('box');
var nodes=box.childNodes;
 
function addArray(text){
/*
因为Array是一个类,不能直接引用,需要获取原型后才能使用。
如果要直接引用,需要实例化Array,如下。
var array = new Array();
array.slice.call(arguments);

slice()在数组中是返回数组,如果是一个参数,则输出从开始位置到结束位置的所有元素
call() this指向addArray()函数,这里只是个参数,则将参数值给Array用,
*/
return Array.prototype.slice.call(text);
}

var newarray=addArray(nodes);
newarray.push('<li>节点四</li>');
console.log(newarray);
这个方法方便高效,但是在IE低版本中有问题
完美解决的办法
/完美方法,使用try...catch方法,当在IE低版本中时候主动抛出错误
 
var box=document.getElementById('box');
var nodes=box.childNodes;
 
function addArray(text){
var array=null;
try{
return Array.prototype.slice.call(text);
}catch(e){
array=new Array();
for(var i=0;i<text.length;i++){
array.push(text[i]);
}
}
return array;
}

var newarray=addArray(nodes);
newarray.push('<li>节点四</li>');
console.log(newarray);
 

猜你喜欢

转载自www.cnblogs.com/fanbulaile/p/10235051.html
今日推荐