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 相关文章推荐
js实现键盘控制DIV移动的方法
Jan 10 Javascript
微信支付如何实现内置浏览器的H5页面支付
Sep 25 Javascript
JS+CSS实现六级网站导航主菜单效果
Sep 28 Javascript
在Linux系统中搭建Node.js开发环境的简单步骤讲解
Jan 26 Javascript
jquery跟随屏幕滚动效果的实现代码
Apr 13 Javascript
从零开始学习Node.js系列教程五:服务器监听方法示例
Apr 13 Javascript
node中koa中间件机制详解
Aug 22 Javascript
详解wow.js中各种特效对应的类名
Sep 13 Javascript
JS实现显示当前日期的实例代码
Jul 03 Javascript
使用JavaScript实现node.js中的path.join方法
Aug 12 Javascript
解决Vue的项目使用Element ui 走马灯无法实现的问题
Aug 03 Javascript
AngularJs的$http发送POST请求,php无法接收Post的数据问题及解决方案
Aug 13 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程序中的常见漏洞进行攻击(下)
2006/10/09 PHP
php采用curl模仿登录人人网发布动态的方法
2014/11/07 PHP
Yii2搭建后台并实现rbac权限控制完整实例教程
2016/04/28 PHP
PHP扩展mcrypt实现的AES加密功能示例
2019/01/29 PHP
Prototype中dom对象方法汇总
2008/09/17 Javascript
JS 类型转换常见方法小结
2010/05/31 Javascript
如何确保JavaScript的执行顺序 之jQuery.html并非万能钥匙
2011/03/03 Javascript
jquery 笔记 事件
2011/11/02 Javascript
js操作CheckBoxList实现全选/反选(在客服端完成)
2013/02/02 Javascript
jquery清空表单数据示例分享
2014/02/13 Javascript
JavaScript基础篇(3)之Object、Function等引用类型
2015/11/30 Javascript
JS实现合并两个数组并去除重复项只留一个的方法
2015/12/17 Javascript
JavaScript获取键盘按键的键码(参照表)
2017/01/10 Javascript
微信小程序实现带刻度尺滑块功能
2017/03/29 Javascript
JavaScript中闭包的详解
2017/04/01 Javascript
浅谈vue-lazyload实现的详细过程
2017/08/22 Javascript
微信小程序显示下拉列表功能【附源码下载】
2017/12/12 Javascript
javascript利用键盘控制小方块的移动
2020/04/20 Javascript
[52:57]2014 DOTA2国际邀请赛中国区预选赛 LGD-CDEC VS HGT
2014/05/21 DOTA
Python内置函数的用法实例教程
2014/09/08 Python
如何使用Python 打印各种三角形
2019/06/28 Python
PYTHON发送邮件YAGMAIL的简单实现解析
2019/10/28 Python
简单了解为什么python函数后有多个括号
2019/12/19 Python
多个python文件调用logging模块报错误
2020/02/12 Python
Python 格式化打印json数据方法(展开状态)
2020/02/27 Python
Python变量及数据类型用法原理汇总
2020/08/06 Python
Django-silk性能测试工具安装及使用解析
2020/11/28 Python
HTML5中Localstorage的使用教程
2015/07/09 HTML / CSS
Tretorn美国官网:瑞典外套和鞋类品牌,抵御风雨
2018/07/19 全球购物
运动会跳远广播稿
2014/02/04 职场文书
四年大学自我鉴定
2014/02/17 职场文书
2015新员工工作总结范文
2015/10/15 职场文书
某某店铺的开业庆典主持词范本
2019/11/25 职场文书
MySQL数据迁移相关总结
2021/04/29 MySQL
JavaScript如何优化逻辑判断代码详解
2021/06/08 Javascript
JavaScript异步操作中串行和并行
2021/11/20 Javascript