js遍历

NodeIterator

比较简单的迭代器

创建 document.createNodeIterator(root,   whatToShow,   filter  ,  false )

root根节点    whatToShow表示要访问哪些结点代码,通常是NodeFilter.SHOW_ELEMENT

filter过滤器,有两种表示方法,一个对象或者一个函数,后面的false不用理

            var filter={
                acceptNode:function  (node) {//只能有这个函数
                    return node.tagName.tolowerCase()=="p"?
                    NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_SKIP;
                }
            }
            var filter=function  (node) {//只能有这个函数
                    return node.tagName.toLowerCase()=="p"?
                    NodeFilter.FILTER_ACCEPT:NodeFilter.FILTER_SKIP;
            }

一开始不是第一个结点 用   a.nextNode(),相应的有a.previousNode()

迭代的代码

            var a=document.createNodeIterator(c,NodeFilter.SHOW_ELEMENT,filter,false);
            var node=a.nextNode();
            for(;node!==null;node=a.nextNode()){
                console.log(node.tagName);
            }

TreeWalker

在filter的点上,多了个NodeFilter.FILTER_REJECT,这个表示在条结点的时候,会整个跳过

在到迭代器是,firstChild就是可以用了

然而,他的强大才开始

他可以用nextSibling()和previousSibling()

 

posted on 2016-09-18 21:10  Kooing  阅读(380)  评论(0编辑  收藏  举报

导航