JQuery遍历DOM节点的方法


Posted in Javascript onJune 11, 2015

本文实例讲述了JQuery遍历DOM节点的方法。分享给大家供大家参考。具体分析如下:

本节的核心是介绍JQuery的DOM操作,前面介绍了很多创建、删除、替换等等节点操作。这里介绍如何遍历节点,选中临近节点等的一些方法。

children()方法

该方法用于取得匹配元素的子元素集合。根据DOM树的结构,可以知道各个元素之间的关系以及它们子节点的个数。

下面使用children()方法来获取匹配元素的所有子元素的个数。

var $body = $("body").children(); 
var $p = $("p").children(); 
var $ul = $("ul").children(); 
alert( $body.length ); // <body>元素下有2个子元素 
alert( $p.length );  // <p>元素下有0个子元素 
alert( $ul.length ); // <p>元素下有3个子元素 
for(var i=0;i< $ul.length;i++){ 
  alert( $ul[i].innerHTML ); 
}

PS:children()方法只考虑子元素而不考虑任何后代元素。

next()方法

该方法用于取得匹配元素后面紧邻的同辈元素。从DOM树的结构中可以知道p元素的下一个同辈节点是ul,因此可以通过next()方法来获取ul元素,代码如下:

var $p1 = $("p").next();
// 紧邻p元素后的同辈元素

prev()方法

该方法用于取得匹配元素前面紧邻的同辈元素。从DOM树的结构中可以知道ul元素的上一个同辈节点是p,因此可以通过prev()方法来获取p元素,代码如下:

var $ul = $("ul").prev();
// 紧邻ul元素前的同辈元素

siblings()方法

该方法用于取得匹配元素前后所有的同辈元素。以DOM树的结构为例。ul元素和p元素互为同辈元素,ul元素下的3个li元素也互为同辈元素。

如果要获取p元素的同辈元素,则可以使用如下代码:

var $p2 = $("p").siblings();
// 紧邻p元素的唯一同辈元素

closest()方法

它用来取得最近的匹配元素。首先检查当前元素是否匹配,如果匹配则直接返回元素本身。如果不匹配则向上查找父元素,逐级向上直到找到匹配选择器的元素。如果什么都没找到则返回一个空的JQuery对象。

比如,给点击的目标元素的最近的li元素添加颜色,可以使用如下代码:

$(document).bind("click", function (e) { 
 $(e.target).closest("li").css("color","red"); 
})

除此之外,在JQuery中还有很多遍历节点的方法,例如find()、filter()、nextAll()、prevAIl()、parent()和parents()等,此处不再赘述,读者可以查看附录的JQuery速查表文档。值得注意的是,这些遍历DOM方法有一个共同点,都可以使用JQuery表达式作为它们的参数来筛选元素。

希望本文所述对大家的jQuery程序设计有所帮助。

Javascript 相关文章推荐
JavaScript在Android的WebView中parseInt函数转换不正确问题解决方法
Apr 25 Javascript
js实现简单div拖拽功能实例
May 12 Javascript
AngularJs bootstrap搭载前台框架——js控制部分
Sep 01 Javascript
JavaScript、C# URL编码、解码总结
Jan 21 Javascript
利用ES6语法重构React组件详解
Mar 02 Javascript
Angularjs中使用指令绑定点击事件的方法
Mar 30 Javascript
xmlplus组件设计系列之图标(ICON)(1)
May 05 Javascript
探究react-native 源码的图片缓存问题
Aug 24 Javascript
js 将canvas生成图片保存,或直接保存一张图片的实现方法
Jan 02 Javascript
vue实现裁切图片同时实现放大、缩小、旋转功能
Mar 02 Javascript
基于vue-cli3创建libs库的实现方法
Dec 04 Javascript
js实现飞机大战小游戏
Aug 26 Javascript
jQuery插件animateSlide制作多点滑动幻灯片
Jun 11 #Javascript
简介JavaScript中的setDate()方法的使用
Jun 11 #Javascript
JQuery实现样式设置、追加、移除与切换的方法
Jun 11 #Javascript
在JavaScript中操作时间之getYear()方法的使用教程
Jun 11 #Javascript
JavaScript中getUTCSeconds()方法的使用详解
Jun 11 #Javascript
JQuery节点元素属性操作方法
Jun 11 #Javascript
JQuery包裹DOM节点的方法
Jun 11 #Javascript
You might like
通过php动态传数据到highcharts
2017/04/05 PHP
PHP实现字母数字混合验证码功能
2019/07/11 PHP
innerHTML 和 getElementsByName 在IE下面的bug 的解决
2010/04/09 Javascript
腾讯的ip接口 方便获取当前用户的ip地理位置
2010/11/25 Javascript
js对象关系图 方便dom操作
2012/03/18 Javascript
使用jQuery Ajax功能时需要注意的一个问题(内存溢出)
2012/05/30 Javascript
javascript学习笔记(八)正则表达式
2014/10/08 Javascript
JavaScript常用脚本汇总(一)
2015/03/04 Javascript
包含中国城市的javascript对象实例
2015/08/03 Javascript
JavaScript中的函数(二)
2015/12/23 Javascript
Chrome调试折腾记之JS断点调试技巧
2017/09/11 Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
2018/10/02 Javascript
Vue使用lodop实现打印小结
2019/07/06 Javascript
微信小程序自定义单项选择器样式
2019/07/25 Javascript
js实现打字小游戏
2019/12/17 Javascript
[01:34]2014DOTA2 TI预选赛预选赛 选手比赛房大揭秘!
2014/05/20 DOTA
零基础写python爬虫之神器正则表达式
2014/11/06 Python
详解python使用递归、尾递归、循环三种方式实现斐波那契数列
2018/01/16 Python
python实现KNN分类算法
2019/10/16 Python
Flask框架路由和视图用法实例分析
2019/11/07 Python
Python计算不规则图形面积算法实现解析
2019/11/22 Python
python保留小数位的三种实现方法
2020/01/07 Python
python pprint模块中print()和pprint()两者的区别
2020/02/10 Python
使用Python FastAPI构建Web服务的实现
2020/06/08 Python
html5视频自动横过来自适应页面且点击播放功能的实现
2020/06/03 HTML / CSS
匡威比利时官网:Converse Belgium
2017/04/13 全球购物
伦敦剧院及景点门票:Encore Tickets
2018/07/01 全球购物
PHP中如何使用Cookie
2015/10/28 面试题
判断单链表中是否存在环
2012/07/16 面试题
测控技术与通信工程毕业生自荐信范文
2013/12/28 职场文书
产品包装策划方案
2014/05/18 职场文书
清正廉洁演讲稿
2014/05/22 职场文书
个人合伙协议书范本
2014/10/14 职场文书
离婚民事起诉状
2015/08/03 职场文书
导游词之茶卡盐湖
2019/11/26 职场文书
python实现层次聚类的方法
2021/11/01 Python