原文:JS中childNodes深入学习

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
</head>
<body>
<div id="box">
<div></div>
<div></div>
<div></div>
</div> <script type="text/javascript">
var getObjByID = function (id) {
return document.getElementById(id);
} var box = getObjByID("box"); var child = box.childNodes; //初学者可能会以为这里输出的是3,其实不然,结果可能是 3 或者 7
document.write("box下的子节点个数:" + child.length + "<br/>"); /* 为什么可能会是7呢,说明如下: 首先,一个元素的 childNodes 包含了3种类型的节点(元素节点; 属性节点; 文本节点) 之前之所以会认为输出是3,是因为我们只关注了元素节点(即:里面的3个div), 忽略了属性节点和文本节点的存在。 我们可以通过 nodeType 属性来提取各个节点,nodeType值与节点关系如下: nodeType === 1 元素节点
nodeType === 2 属性节点
nodeType === 3 文本节点 实现代码如下: */ var arrElements = [], arrAttributes = [], arrTexts = []; for (var i = 0; i < child.length; i++) {
//元素节点
if (child[i].nodeType === 1) {
arrElements.push(child[i]);
}
//属性节点
if (child[i].nodeType === 2) {
arrAttributes.push(child[i]);
}
//文本节点
if (child[i].nodeType === 3) {
arrTexts.push(child[i]);
} //去除 空白符 文本节点
// if (child[i].nodeType === 3 && /\S/.test(child[i].nodeValue)) {
// arrTexts.push(child[i]);
// }
} /*我们将各个节点分别提取存储在数组中,现在输出查看结果:*/ document.write("元素节点个数:" + arrElements.length + "<br/>"); //3
document.write("属性节点个数:" + arrAttributes.length + "<br/>"); //0
document.write("文本节点个数:" + arrTexts.length + "<br/>"); //4或0 /* 这里存在一个浏览器兼容问题
在 firefox,chrome,ie9+ 等浏览器中 文本节点 的个数是 4
而在 ie8- 浏览器中 文本节点 的个数是 0 原因:
在 firefox,chrome,ie9+ 会把 换行(空白符) 也算作一个文本节点
而在 ie8- 换行(空白符)是不算作文本节点的 解决方案:
获取文本节点时,多加一个判断条件,即:如果不是 空白符 则添加,反之则不添加 代码如下: //文本节点
if (child[i].nodeType === 3 && /\S/.test(child[i].nodeValue)) {
arrTexts.push(child[i]);
} 在上面for循环代码中加上 /\S/.test(child[i].nodeValue) 这个条件后再运行,你就会
发现所有浏览器 文本节点 个数都是0了 如果对这个条件不懂的,可以去看下正则和test的用法。
http://www.jb51.net/tools/zhengze.html */ /* 节点 除了有 nodeType 属性外,还有两个常用属性 nodeName 和 nodeValue 元素节点的 nodeName 是标签名称
属性节点的 nodeName 是属性名称
文本节点的 nodeName 永远是 #text 因此判断一个节点是否为文本节点,除了 child[i].nodeType === 3
还可以用 child[i].nodeName == "#text" 元素节点的 nodeValue 是null
属性节点的 nodeValue 是属性的值
文本节点的 nodeValue 是文本节点的内容 nodeValue 虽然是一个读/写 属性,但不能对 元素节点 设置 nodeValue 值 将上面的html代码修改如下: <div id="box">
111
<div></div>
<div></div>
<div></div>
</div> 加了 111 ,此时运行,文本节点 个数为1,且其nodeValue为 111
我们可将其打印查看。
document.write("第1个文本节点的值为:"+ arrTexts[0].nodeValue); 如果你没加 111, 那么运行此行代码会报错。因为没加 111 的话,文本节点个数为0个
arrTexts[0] 不存在。
*/ /* 通常我们都是获取元素节点,因此有个更好的办法 代码如下:
*/ var child_div = box.getElementsByTagName("div"); document.write("box下div元素节点个数:" + child_div.length); </script>
</body>
</html>

所有讲解都写在注释里面了,有错误或不足的地方还望大神们指点,谢谢!

JS中childNodes深入学习的更多相关文章

  1. js中关于prototype学习(2015年1月5号晚)

    prototype在js中为原型,只要是对象都有原型,最高原型为Object. 函数作为一特殊的对象,下面探讨prototype(原型)和function(函数)之间的关系. function A ( ...

  2. js中this指向学习总结

      在面向对象的语言中(例如Java,C#等),this 含义是明确且具体的,即指向当前对象.一般在编译期绑定. 然而js中this 是在运行期进行绑定的,这是js中this 关键字具备多重含义的本质 ...

  3. JS中Generator的学习小记

    Generator的异步实现 整理了一下在学习和使用JS异步过程中的一些知识点.核心是在Generator实例的的回调中调度实例的下一步,同样的思想也能用于其它语言.比如Python中使用Genera ...

  4. Js中Array数组学习总结

    第一次写博客...有点方... 小白一枚(是真的小白),自学前端,下面来说说我在学习过程中总结的一些数组操作,如果说哪有错误,请各位大神多多指出,小的虚心接受. 引用类型分为Object类型(所谓的对 ...

  5. JavaScript学习12 JS中定义对象的几种方式

    JavaScript学习12 JS中定义对象的几种方式 JavaScript中没有类的概念,只有对象. 在JavaScript中定义对象可以采用以下几种方式: 1.基于已有对象扩充其属性和方法 2.工 ...

  6. JavaScript学习笔记——JS中的变量复制、参数传递和作用域链

    今天在看书的过程中,又发现了自己目前对Javascript存在的一个知识模糊点:JS的作用域链,所以就通过查资料看书对作用域链相关的内容进行了学习.今天学习笔记主要有这样几个关键字:变量.参数传递.执 ...

  7. JavaScript学习12 JS中定义对象的几种方式【转】

    avaScript学习12 JS中定义对象的几种方式 转自:  http://www.cnblogs.com/mengdd/p/3697255.html JavaScript中没有类的概念,只有对象. ...

  8. Javascript高级编程学习笔记(3)—— JS中的数据类型(1)

    前一段时间由于事情比较多,所以笔记耽搁了一段时间,从这一篇开始我会尽快写完这个系列. 文章中有什么不足之处,还望各位大佬指出. JS中的数据类型 上一篇中我写了有关JS引入的Script标签相关的东西 ...

  9. js中的基本类型与引用类型学习

    一.基本数据类型 ECMAScript 有 5 种原始类型(primitive type),即 Undefined.Null.Boolean.Number 和 String,也称为基本数据类型,ES6 ...

随机推荐

  1. JavaScript之三:jQuery插件开发(一)

    在早期的开发中,正如前面闭包中所提到的那样,人们一开始并没有意识到要开发出插件这么个玩意儿,都是遇到啥写啥.在长期的工作中,人们发现很多代码是重复的,写了一遍又一遍,以登录页面为例,每写一次都需要重新 ...

  2. 阿里巴巴2014研发project师实习生面试经历

    java研发project师的初面是在上周三进行的,终于结果到了晚上才出,而没有通过的则是一结束网上就更新了状态.之后阿里通知这周三,也就是今天进行二面. 凑巧的是今早被舍友吵醒,中午那个困啊,但没时 ...

  3. [INS-20802] Oracle Database Configuration Assistant 失败

    1.错误原因    [INS-20802] Oracle Database Configuration Assistant 失败 2.错误原因 3.解决方案 版权声明:本文博主原创文章.博客,未经同意 ...

  4. sdut 在机器上面向对象编程练习11(运算符重载)

    在机器上面向对象编程练习11(运算符重载) Time Limit: 1000MS Memory limit: 65536K 标题叙述性说明 有两个矩阵a和b,均为2行3列,求两个矩阵之和.重载运算符& ...

  5. 新的学生说说我是如何靠APP发展赢得了亿万

    郝萌主倾心贡献,尊重作者的劳动成果,请勿转载. 假设文章对您有所帮助,欢迎给作者捐赠.支持郝萌主,捐赠数额任意.重在心意^_^ 我要捐赠: 点击捐赠 Cocos2d-X源代码下载:点我传送 14年踏入 ...

  6. boxfilter 实现

    A implementation of boxfilter boxfilter 是均值滤波的一种改进.在以下这篇blog里面有介绍. http://www.cnblogs.com/easymind22 ...

  7. 使用 Advanced Installer 打包 一键安装Web应用程序

    原文:使用 Advanced Installer 打包 一键安装Web应用程序 安装预览: 资源下载: 示例安装包 操作流程: 1.新建Asp.net Application. 2.设置应用程序名称和 ...

  8. Git 少用 Pull 多用 Fetch 和 Merge(转)

    英文原文:git: fetch and merge, don’t pull This is too long and rambling, but to steal a joke from Mark T ...

  9. wordpress常见的问题

    nginx如webserver,wordpress上传主题错误 413 Request Entity Too Large 解决: vim /usr/local/nginx/conf/nginx.con ...

  10. poj3417 Network 树形Dp+LCA

    题意:给定一棵n个节点的树,然后在给定m条边,去掉m条边中的一条和原树中的一条边,使得树至少分为两部分,问有多少种方案. 神题,一点也想不到做法, 首先要分析出加入一条边之后会形成环,形成环的话,如果 ...