NodeList集合跟Array数组的区别
首先来看看什么是NodeList,NodeList跟arguments都不是普通的数组,他们有数组的一些基本属性但是又不完全是数组。下面是在Mozilla上面找到的定义:
This is a commonly used type which is a collection of nodes returned by getElementsByTagName, getElementsByTagNameNS, and Node.childNodes. The list is live, so changes to it internally or externally will cause the items they reference to be updated as well. Unlike NamedNodeMap, NodeList maintains a particular order (document order). The nodes in a NodeList are indexed starting with zero, similarly to JavaScript arrays, but a NodeList is not an array.
由字面意思来看NodeList是DOM操作(getElementsByTagName等)取出来的集合,是集合而不是普通的数组,但是他们有数组的一些属性,例如length、下标索引,但是他们也有自己的属性,例如item,另外NodeList最大的特点就是时效性(live)。
NodeList的时效性
我们来看下面的代码:
<ul id="nodelist"> <li class="lis">index0</li> <li class="lis">index1</li> <li class="lis">index2</li> <li class="lis">index3</li> <li class="lis">index4</li> </ul>
javascript代码如下:
var myUl = document.getElementById('nodelist'); var lis = myUl.getElementsByTagName('li');
lis是一个NodeList集合,具有时效性,所谓的时效性就是我们在修改li的同时,会反映到lis上来,这与array是不同的,例如我们把第一个li插入到ul的底部,那么lis也会发生相应的变化:
//把第一个li插入的ul的底部 myUl.appendChild(myUl.getElementsByTagName('li').item(0)); console.log(lis[0]);//输出的是原来ul的第二个li
所以我们应该在写代码的时候注意NodeList的时效性,不然就会犯一些错误,
例如下面的代码(来自Jeff Wong):
<div id="divAnchor"> <a href="http://www.js8.in">link test</a> </div>
var anchors = document.getElementsByTagName("a"); for (i = 0; i < anchors.length; i++) { var ele= document.createElement("a"); ele.setAttribute("href", "http://js8.in/"); ele.appendChild(document.createTextNode("new link test")); document.getElementById("divAnchor").appendChild(ele); //div附加一个新链接 }
本意是在div内,已经存在的a元素后再附加一个a元素。但是,您可以运行一下,浏览器crash掉了吧?楼猪这里IE直接挂掉,FF提示脚本正忙,是否停止脚本运行,点击停止后,页面内已经生成了n多个a链接。这是因为NodeList的length会不断变化上升,循环循环再循环,最后成了个死循环。
NodeList转化为数组
NodeList具有length,下标索引这些数组的属性特征,但是我们不可以使用数组的push、pop、shift、unshift等数组原生的方法,这样我们就不能使用数组的原生方法来操作NodeList,所以我们要吧NodeList转化为数组,方便操作。下面的代码就可以把NodeList转化为普通的数组。
function collectionToArray(collection){ var ary = []; for(var i=0, len = collection.length; i < len; i++){ ary.push(collection[i]); } return ary; }
建议继续学习:
- 为什么数组标号是从0开始的? (阅读:5120)
- C语言结构体里的成员数组和指针 (阅读:5037)
- 将数组定义为常量 (阅读:4663)
- Tips of Linux C programming (阅读:4121)
- xml转数组的方法 (阅读:3645)
- javascript扩展Array(数组)类 (阅读:3330)
- 动态数组的 C 实现 (阅读:3202)
- php数组排序 (阅读:3110)
- javascript数组排序的问题 (阅读:3041)
- 关于Cannot use a scalar value as an array的解决办法 (阅读:2970)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:断桥残雪 来源: 断桥残雪部落格
- 标签: NodeList 数组
- 发布时间:2011-05-25 13:44:14
- [48] WEB系统需要关注的一些点
- [47] Oracle MTS模式下 进程地址与会话信
- [45] 【社会化设计】自我(self)部分――欢迎区
- [45] Go Reflect 性能
- [45] IOS安全–浅谈关于IOS加固的几种方法
- [45] android 开发入门
- [44] Twitter/微博客的学习摘要
- [43] find命令的一点注意事项
- [42] 图书馆的世界纪录
- [42] 关于恐惧的自白