javascript获取网页中指定节点的父节点、子节点的方法小结


Posted in Javascript onApril 24, 2013

我们在实际的开发当中经常要获取页面中某个html元素,动态的更新该元素的样式、内容属性等。
那么如何获取要更新的这些元素呢?用JavaScript获取这些节点的方法有很多种,下面是总结的一些方法.

1. 通过document节点获取
(1) document.getElementById(elementId):该方法通过节点的ID,可以准确获得需要的元素,是比较简单快捷的方法。如果页面上含有多个相同id的节点,那么只返回第一个节点。
如 今,已经出现了如prototype、Mootools等多个JavaScript库,它们提供了更简便的方法:$(id),参数仍然是节点的id。这个 方法可以看作是document.getElementById()的另外一种写法,不过$()的功能更为强大,具体用法可以参考它们各自的API文档。
(2)document.getElementsByName(elementName): 该方法是通过节点的name获取节点,从名字可以看出,这个方法返回的不是一个节点元素,而是具有同样名称的节点数组。然后,我们可以通过要获取节点的某 个属性来循环判断是否为需要的节点。
例如:在HTML中checkbox和radio都是通过相同的name属性值,来标识一个组内的元素。如果我们现在要获取被选中的元素,首先获取改组元素,然后循环判断是节点的checked属性值是否为true即可。
(3)document.getElementsByTagName(tagName): 该方法是通过节点的Tag获取节点,同样该方法也是返回一个数组,例如:document.getElementsByTagName('A')将会返回 页面上所有超链接节点。在获取节点之前,一般都是知道节点的类型的,所以使用该方法比较简单。但是缺点也是显而易见,那就是返回的数组可能十分庞大,这样 就会浪费很多时间。那么,这个方法是不是就没有用处了呢?当然不是,这个方法和上面的两个不同,它不是document节点的专有方法,还可以应用其他的 节点,下面将会提到。

2、通过父节点获取
(1)parentObj.firstChild:如果节点为已知节点 (parentObj)的第一个子节点就可以使用这个方法。这个属性是可以递归使用的,也就是支持 parentObj.firstChild.firstChild.firstChild...的形式,如此就可以获得更深层次的节点。
(2)parentObj.lastChild:很显然,这个属性是获取已知节点(parentObj)的最后一个子节点。与firstChild一样,它也可以递归使用。
在使用中,如果我们把二者结合起来,那么将会达到更加令人兴奋的效果,即:parentObj.firstChild.lastChild.lastChild...
(3)parentObj.childNodes:获取已知节点的子节点数组,然后可以通过循环或者索引找到需要的节点。
注意:经测试发现,在IE7上获取的是直接子节点的数组,而在Firefox2.0.0.11上获取的是所有子节点即包括子节点的子节点。
(4)parentObj.children:获取已知节点的直接子节点数组。
注意:经测试,在IE7上,和childNodes效果一样,而Firefox2.0.0.11不支持。这也是为什么我要使用和其他方法不同样式的原因。因此不建议使用。
(5)parentObj.getElementsByTagName(tagName): 使用方法不再赘述,它返回已知节点的所有子节点中类型为指定值的子节点数组。例 如:parentObj.getElementsByTagName('A')返回已知的子节点中的所有超链接。

3、通过临近节点获取
(1)neighbourNode.previousSibling:获取已知节点(neighbourNode)的前一个节点,这个属性和前面的firstChild、lastChild一样都似乎可以递归使用的。
(2)neighbourNode.nextSibling:获取已知节点(neighbourNode)的下一个节点,同样支持递归。

4、通过子节点获取
(1)childNode.parentNode:获取已知节点的父节点。
上面提到的方法,只是一些基本的方法,如果使用了Prototype等JavaScript库,可能还获得其他不同的方法,例如通过节点的class获取等等。不过,如果能够灵活运用上面的各种方法,相信应该可以应付大部分的程序

Javascript 相关文章推荐
用javascript动态调整iframe高度的方法
Mar 06 Javascript
利用JavaScript实现新闻滚动效果(实例代码)
Nov 27 Javascript
JavaScript学习笔记之基础语法
Jan 22 Javascript
详解JavaScript逻辑Not运算符
Dec 04 Javascript
jquery.validate 自定义验证方法及validate相关参数
Jan 18 Javascript
js面向对象的写法
Feb 19 Javascript
AngularJS中watch监听用法分析
Nov 04 Javascript
Bootstrap3 datetimepicker控件使用实例
Dec 13 Javascript
Vue 实用分页paging实例代码
Apr 12 Javascript
获取本机IP地址的实例(JavaScript / Node.js)
Nov 24 Javascript
深入浅析Vue全局组件与局部组件的区别
Jun 15 Javascript
JS字符串补全方法padStart()和padEnd()
May 27 Javascript
jQuery文本框(input textare)事件绑定方法教程
Apr 24 #Javascript
为JS扩展Array.prototype.indexOf引发的问题探讨及解决
Apr 24 #Javascript
Dom 学习总结以及实例的使用介绍
Apr 24 #Javascript
jQuery 关于伪类选择符的使用说明
Apr 24 #Javascript
关于ExtJS4.1:快捷键支持的问题
Apr 24 #Javascript
Jquery实现三层遍历删除功能代码
Apr 23 #Javascript
jQuery获取浏览器中的分辨率实现代码
Apr 23 #Javascript
You might like
php Smarty模板生成html文档的方法
2010/04/12 PHP
PHP函数分享之curl方式取得数据、模拟登陆、POST数据
2014/06/04 PHP
PHP实现截取中文字符串不出现?号的解决方法
2016/12/29 PHP
javascript 自动填写表单的实现方法
2010/04/09 Javascript
javascript 二分法(数组array)
2010/04/24 Javascript
JS函数验证总结(方便js客户端输入验证)
2010/10/29 Javascript
避免回车键导致的页面无意义刷新的解决方法
2011/04/12 Javascript
JavaScript取得鼠标绝对位置程序代码介绍
2012/09/16 Javascript
jQuery.Validate验证库的使用介绍
2013/04/26 Javascript
如何使用jQUery获取选中radio对应的值(一句代码)
2013/06/03 Javascript
基于jquery实现的图片在各种分辨率下未知的容器内上下左右居中
2014/05/11 Javascript
JavaScript中的依赖注入详解
2015/03/18 Javascript
JS实现对中文字符串进行utf-8的Base64编码的方法(使其与Java编码相同)
2016/06/21 Javascript
JavaScript实现的XML与JSON互转功能详解
2017/02/16 Javascript
微信小程序实现留言板(Storage)
2018/11/02 Javascript
vue实现PC端录音功能的实例代码
2019/06/05 Javascript
通过javascript实现段落的收缩与展开
2019/06/26 Javascript
vue的滚动条插件实现代码
2019/09/07 Javascript
[49:02]KG vs Infamous 2019国际邀请赛淘汰赛 败者组BO1 8.20.mp4
2020/07/19 DOTA
[04:20]DOTA2-DPC中国联赛 正赛 VG vs LBZS 选手采访 1月19日
2021/03/11 DOTA
基于Python的关键字监控及告警
2017/07/06 Python
python中利用h5py模块读取h5文件中的主键方法
2018/06/05 Python
对python3新增的byte类型详解
2018/12/04 Python
python操作openpyxl导出Excel 设置单元格格式及合并处理代码实例
2019/08/27 Python
python实现图像外边界跟踪操作
2020/07/13 Python
优秀乡村医生先进事迹材料
2014/08/23 职场文书
安全例会汇报材料
2014/08/23 职场文书
群众路线教育实践活动民主生活会个人检查对照思想汇报
2014/10/04 职场文书
护士个人年终总结
2015/02/13 职场文书
2015年教师节慰问信
2015/03/23 职场文书
《小蝌蚪找妈妈》教学反思
2016/02/23 职场文书
Oracle 数据仓库ETL技术之多表插入语句的示例详解
2021/04/12 Oracle
一文彻底理解js原生语法prototype,__proto__和constructor
2021/10/24 Javascript
基于Pygame实现简单的贪吃蛇游戏
2021/12/06 Python
灵能百分百第三季什么时候来?
2022/03/15 日漫
漫画「你在春天醒来」第10卷封面公开
2022/03/21 日漫