zoukankan      html  css  js  c++  java
  • 深入理解 NodeList

    在web前端编程中,我们通常会通过document.getElementsByTagName的方法取出一组相同标签的dom元素,比如:

    var list = document.getElementsByTagName("li");  
    for (i = 0; i < list.length; i++) {   
        var lis = list[i];//取某一个元素  
        //more code
    } 

      首先说明:通过这种方法获取的这一组dom元素,不是数组(Array),而是NodeList,NodeList不是数组。
      我们可以直接获取它的length属性,还可以根据索引取到对应的单独元素,难道不是数组吗?如果,你已经对javascript稍微有过深入的了解,有length属性,可以索引取值,一定是数组吗,好像arguments也会这么一手吧,arguments是数组?当然不是!

    1、NodeList为什么不是数组!

      验证NodeList是不是数组,最直接的方法也许是试一下Array专有的push和pop方法:

    var list = document.getElementsByTagName("li");
    var a = document.createElement("a");//新建一个a元素
    list.push(a);//push   
    var element= list.pop();//pop

      通过测试,上面的代码不管是push还是pop方法,无一例外的会提示你没有push或者pop方法。当然这种测试有点片面。我们完全可以像证明arguments不是数组一样,也用同样的方法证明NodeList不是数组。那就是修改它的原型,来测试。看下面的代码吧:

    复制代码
    Array.prototype.testNodeList = "test nodelist"; //数组添加原型属性
    function NodeList() {   
        var list = document.getElementsByTagName("li");   
        alert(list.testNodeList);   
    }   
    function test() {   
        alert(new Array().testNodeList); //test nodelist   
        NodeList(); //undefined   
    }   
    test(); //测试一下  
    复制代码

      通过上面的分析,我们可以肯定NodeList不是数组(Array)了。那么如何按照我们操作集合的习惯操作NodeList呢?

    2、像操作Array一样操作NodeList

      既然NodeList有length,可以for循环索引取值,转换成数组还不是轻而易举。最直接的思路是这样的:先new一个Array,遍历NodeList,然后将每一个单独的元素push到数组变量里,最后操作数组变量。

    复制代码
    var arr = [];
    var list = document.getElementsByTagName("li"); 
    for (var i = 0; i < list.length; i++) {  
        var li = list[i]; 
        arr.push(li); //arr就是我们要的数组  
    } 
    复制代码
  • 相关阅读:
    Aseprite+Cocos:打包像素画图,导入到cocos里并动起来
    自定义博客园个人皮肤
    埃航和737MAX坠毁:软件优先级问题
    淘宝网——软件质量属性场景分析
    王概凯《架构漫谈》阅读笔记
    2965 -- The Pilots Brothers' refrigerator
    UVa10082 -- WERTYU
    1753 -- Flip Game
    1083 -- Moving Tables
    2159 -- Ancient Cipher
  • 原文地址:https://www.cnblogs.com/dexjinkey/p/6117982.html
Copyright © 2011-2022 走看看