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和css代码压缩工具[附JAVA环境配置方法]
Apr 16 Javascript
修改jquery里的dialog对话框插件为框架页(iframe) 的方法
Sep 14 Javascript
Javascript面向对象扩展库代码分享
Mar 27 Javascript
jQuery学习笔记(3)--用jquery(插件)实现多选项卡功能
Apr 08 Javascript
当达到输入长度时表单自动切换焦点
Apr 06 Javascript
js老生常谈之this,constructor ,prototype全面解析
Apr 05 Javascript
vue绑定class与行间样式style详解
Aug 16 Javascript
webpack2.0配置postcss-loader的方法
Aug 17 Javascript
jQuery实现弹窗下底部页面禁止滑动效果
Dec 19 jQuery
AngularJS使用$http配置对象方式与服务端交互方法
Aug 13 Javascript
JS实现字符串翻转的方法分析
Aug 31 Javascript
4个顶级开源JavaScript图表库
Sep 29 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
超人钢铁侠联手合作?美漫作家呼吁DC漫威合作联动以抵抗疫情
2020/04/09 欧美动漫
PHP 危险函数解释 分析
2009/04/22 PHP
PHP下打开phpMyAdmin出现403错误的问题解决方法
2013/05/23 PHP
Thinkphp多文件上传实现方法
2014/10/31 PHP
PHP调用wsdl文件类型的接口代码分享
2014/11/19 PHP
php内存缓存实现方法
2015/01/24 PHP
JavaScript使用cookie
2007/02/02 Javascript
限制文本字节数js代码
2007/03/06 Javascript
Jquery遍历节点的方法小集
2014/01/22 Javascript
jquery序列化表单去除指定元素示例代码
2014/04/10 Javascript
JS对象与json字符串格式转换实例
2014/10/28 Javascript
WebPack基础知识详解
2017/01/16 Javascript
判断颜色是否合法的正则表达式(详解)
2017/05/03 Javascript
bootstrapvalidator之API学习教程
2017/06/29 Javascript
react redux入门示例
2018/04/19 Javascript
Node.js fs模块(文件模块)创建、删除目录(文件)读取写入文件流的方法
2019/09/03 Javascript
JQuery中的常用事件、对象属性与使用方法分析
2019/12/23 jQuery
[01:13]这,就是刀塔
2014/07/16 DOTA
python学习数据结构实例代码
2015/05/11 Python
如何在sublime编辑器中安装python
2020/05/20 Python
python实现一次性封装多条sql语句(begin end)
2020/06/06 Python
Python matplotlib读取excel数据并用for循环画多个子图subplot操作
2020/07/14 Python
Python3爬虫带上cookie的实例代码
2020/07/28 Python
Python爬取网站图片并保存的实现示例
2021/02/26 Python
使用CSS3创建动态菜单效果
2015/07/10 HTML / CSS
美国Rue La La闪购网站:奢侈品、中高档品牌限时折扣
2016/10/19 全球购物
Ibatis如何调用存储过程
2015/05/15 面试题
什么是用户模式(User Mode)与内核模式(Kernel Mode) ?
2014/07/21 面试题
售后服务经理岗位职责范本
2014/02/22 职场文书
学习十八大报告感言
2014/02/28 职场文书
安全环保标语
2014/06/09 职场文书
保密工作承诺书
2014/08/29 职场文书
仰望星空观后感
2015/06/10 职场文书
新学期小学班主任工作计划
2019/06/21 职场文书
JavaScript实现淘宝商品图切换效果
2021/04/29 Javascript
如何有效防止sql注入的方法
2021/05/25 SQL Server