var box=document.getElementById(‘box‘); var nodes=box.childNodes; function addArray(text){ /* 因为Array是一个类,不能直接引用,需要获取原型后才能使用。 如果要直接引用,需要实例化Array,如下。 v
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);