遍历

“DOM2级遍历和范围”模块定义了两个用于辅助完成顺序遍历DOM结构的类型:NodeIterator和TreeWalker,两个类型能够基于给定的起点对DOM结构执行深度优先(depth-first)的遍历操作,与DOM兼容的浏览器都可以访问到这些类型的对象,IE不支持DOM遍历

使用以下代码检测浏览器对DOM2级的遍历支持情况:

var supportsTraversals=document.implementation.hasFeature("Traversal","2.0");

var supportsNodeIterator=(typeof document.createNodeIterator=="function");

var supportsTreeWalker=(typeof document.createTreeWalker=="function");

DOM遍历是深度优先的DOM结构遍历,移动方向至少有两个(取决于使用的遍历类型)

遍历以给定节点为根,不可能向上超出DOM树的根节点(如果以<body>元素为根,只会向下遍历<body>的子元素,不会访问到<html>节点),访问的顺序是从父节点到子节点,遍历完前一个同胞节点再遍历后一个同胞节点

NodeIterator类型

可以使用document.createNodeIterator()方法创建它的新实例,接收4个参数:

root:作为搜索起点的节点

whatToShow:表示访问哪些节点的数字代码

filter:是一个NodeFilter对象,或者一个表示应该接受还是拒绝某种特定节点的函数

entityReferenceExpansion:布尔值,表示是否扩展实体引用,这个参数在HTML页面中没有用,因为其中的实体引用不能扩展

whatToShow参数是一个位掩码,通过应用一个或者多个过滤器来确定要访问哪些节点,这个参数的值以常量形式在NodeFilter类型中定义

NodeFilter.SHOW_ALL:显示所有类型的节点

NodeFilter.SHOW_ELEMENT:显示元素节点

NodeFilter.SHOW_ATTRIBUTE:显示特性节点。由于DOM结构原因,实际上不能使用这个值

NodeFilter.SHOW_TEXT:显示文本节点

NodeFilter.SHOW_CDATA_SECTION:显示CDATA节点。对HTML页面没有用

NodeFilter.SHOW_ENTITY_REFERENCE:显示实体引用节点。对HTML页面没有用

NodeFilter.SHOW_ENTITY:显示实体节点。对HTML页面没有用

NodeFilter.SHOW_PROCESSING_INSTRUCTION:显示处理指令节点。对HTML页面没有用

NodeFilter.SHOW_COMMENT:显示注释节点

NodeFilter.SHOW_DOCUMENT:显示文档节点

NodeFilter.SHOW_DOCUMENT_TYPE:显示文档类型节点

NodeFilter.SHOW_DOCUMENT_FRAGMENT:显示文档片段节点。对HTML页面没有用

NodeFilter.SHOW_NOTATION:显示符号节点。对HTML页面没有用

除了NodeFilter.SHOW_ALL之外,可以使用按位或操作符组合多个选项

var whatToShow=NodeFilter.SHOW_DOCUMENT|NodeFilter.SHOW_DOCUMENT_TYPE;

可以通过createNodeIterator()方法的filter参数来指定自定义的NodeFilter对象,或者指定一个功能类似节点过滤器的函数,每个NodeFilter对象只有一个方法,即acceptNode();如果应该访问给定节点,该方法返回NodeFilter.FILTER_ACCEPT,否则返回NodeFilter.FILTER_SKIP

NodeFilter是一个抽象的类型,因此不能直接创建它的实例。在必要时,只要创建一个包含acceptNode()方法的对象,然后将这个对象传入createNodeIterator()方法即可

下列代码展示了如何创建一个只显示<p>元素的节点迭代器

var filter={

  acceptNode:function(node){

      return node.tagName.toLowerCase()=="p" ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;

      }

    };

var iterator=document.createNodeIterator(root,NodeFilter.SHOW_ELEMENT,filter,false);

如果不指定过滤器。在第3个参数位置上传入null

NodeIterator类型的2个主要方法是nextNode()和previousNode(),在深度优先的DOM子树遍历中nextNode()方法用于向前一步,previousNode()方法向后退一步

在刚刚创建的NodeIterator对象中,有一个内部指针指向根节点,因此第一次调用nextNode()会返回根节点,当遍历到DOM子树的最后一个节点时nextNode()返回null,previousNode()方法的工作机制类似,但遍历到DOM子树的最后一个节点,且previousNode()返回根节点之后,再次调用它就会返回null

例子

<div id="div1">

  <p><b>Hello</b> world!</p>

  <ul>

    <li>List item 1</li>

    <li>List item 2</li>

    <li>List item 3</li>

  <ul>

</div>

var div=document.getElementById("div1");

var iterator=document.createNodeIterator(div,NodeFilter.SHOW_ELEMENT,null,false);

var node=iterator.nextNode();

while(node!=null){

    alert(node.tagName);

    node=iterator.nextNode();

    }

输出结果是DIV P B UL LI LI LI

JavaScript高级程序设计35.pdf的更多相关文章

  1. JavaScript高级程序设计61.pdf

    JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...

  2. JavaScript高级程序设计60.pdf

    错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...

  3. JavaScript高级程序设计58.pdf

    15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...

  4. JavaScript高级程序设计57.pdf

    表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...

  5. JavaScript高级程序设计55.pdf

    输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...

  6. JavaScript高级程序设计54.pdf

    过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...

  7. JavaScript高级程序设计53.pdf

    共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...

  8. JavaScript高级程序设计52.pdf

    表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...

  9. JavaScript高级程序设计50.pdf

    hashchange事件 HTML5新增了hashchange事件,以便在URL的参数列表(及URL中“#”号后面的所有字符串)发生变化时通知开发人员,之所以新增这个事件,是因为在Ajax应用中,开发 ...

随机推荐

  1. VMProtect使用小计【一】

    文章列表 VMProtect使用小计[一] – 初次使用VMProtect使用小计[二] – 加壳查看VMProtect使用小计[三] – 权限管理 说明 VMProtect的功能我就不说了,详情大家 ...

  2. IOS 学习笔记 2015-04-03 OC-API-文件读写

    // // WPFileHelper.m // OC-API-文件操作 // // Created by wangtouwang on 15/4/3. // Copyright (c) 2015年 w ...

  3. Python没有执行__init__

    疑惑 提出问题 前天同事问我一个问题,为什么这个脚本中的没有调用A 的__init__.脚本如下: class A(object): def __init__(self, *args, **kwarg ...

  4. Cookies和Sseeion的选择

    Cookies和Session都是用来记录个人信息  来保持页面状态 现在介绍些Cookies 的优点 1 把存储数据的压力分担到了客户端 ,这样服务器就少点压力 2 可以用来记录用户状态(如放入用户 ...

  5. web 中 bbs 例子(多次递归)

    数据库设计:create table `header`(  // 父表  parent int not null, //父级  poster varchar(20) not null, //作者  p ...

  6. 《C和指针》章节后编程练习解答参考——6.3

    <C和指针>——6.3 题目: 编写一个函数,把参数字符串中的字符反向排列. 函数原型: void reverse_string(char *string); 要求: 使用指针而不是数组下 ...

  7. after I see Little Dorrit

    也许是我太追名逐利,所以我不肯承认自己花费了大把的时间看电影,通过写博客好像自己从中感悟到了什么,好像看电影也是一种学习的方式. 也许是我平静自内心的方式,我太忙于玩或者学习,甚至没有机会非常沉静 一 ...

  8. SNA社交网络算法

    社交网络需要用到igraph库,所以需要安装.可以在lfd的网站 http://www.lfd.uci.edu/~gohlke/pythonlibs/ 上下载python_igraph,具体的pyth ...

  9. Instruments --- 内存泄露

    虽然iOS 5.0版本之后加入了ARC机制,由于相互引用关系比较复杂时,内存泄露还是可能存在.所以了解原理很重要. 这里讲述在没有ARC的情况下,如何使用Instruments来查找程序中的内存泄露, ...

  10. 关于BootStrap下图标的显示问题

    我现在在做自己的毕业设计,用到了bootstrap的这一套css样式,说句心里话,这一套东西确实很好用,但是一个小问题足足浪费了我将近两个小时. 我的问题是:没有办法使用bootstrap下的图标(很 ...