jQuery获取父元素节点、子元素节点及兄弟元素节点的方法


Posted in Javascript onApril 14, 2016

本文实例讲述了jQuery获取父元素节点、子元素节点及兄弟元素节点的方法。分享给大家供大家参考,具体如下:

先来看这段html代码,整个取节点(父、子、兄弟等)的方法都是围绕这段代码来的:

<ul class="par">
  <li id="firstli">
    <h3 class="title">条目一</h3>
    <ul class="par">
      <li id="dwtedx">第一项</li>
      <li>第二项</li>
    </ul>
  </li>
</ul>

JQUERY 父节点的获取:

jquery获取父元素方法比较多、比如parent()、parents()、closest()、find,first-child这些都能帮你实现查找父节点、子节点、兄弟节点

如我们利用parent()来获取父节点

$("#dwtedx").parent().parent();//取得id为firstli的li节点
$("#dwtedx").parent().parent(".par");//取得最上面的ul节点
$("#dwtedx").parent(".par");
//取得向上第一层的ul节点 以上是通过parent的方式来获取父节点的、大家可以根据自己项目需要来选择方法哈

下面、我们主要来讲一下 parents() 和 closest() 两个方法的区别

1、closest从当前元素开始匹配寻找、parents从父元素开始匹配寻找

2、closest逐级向上查找、直到发现匹配的元素后 就停止了、parents一直向上查找直到根元素、然后把这些元素放进一个临时集合中、再用给定的选择器表达式去过滤

3、closest返回0或1个元素、parents可能包含0 个、1个、或者多个元素

代码可以这样写:

$('#dwtedx').parents('.par');//可以找出所有class为.par的节点
$('#dwtedx').closest('.par'); //可以找出一个父节点、就是上面一层的那个

JQUERY 兄弟节点的获取

jQuery兄弟节点获取、我们的思路是通过当前节点找到父节点、然后通过父节点去找到子节点、代码如下

$(".title").parent().find('ul');
//找到自己的兄弟节点ul 就是通过先找到 h3 与 ul 共同的父节点 li 然后来用 find() 找到 ul

还有一种方法是使用 siblings() 函数、代码如下

$(".title").siblings('ul');
//找到自己的兄弟节点ul

JQUERY 子节点的获取

匹配第一个子元素 :first 只匹配一个元素、而此选择符将为每个父元素匹配一个子元素

$(".par:first-child");
//取得id为firstli的节点

通过选择器去获取、代码如下:

$('#firstli h3.title');
//取得条目一的h3

使用find()函数、上面已经说过了、用法一样

$("#firstli").find("h3");
//找到子兄弟节点h3

使用children()函数、代码如下

$("#firstli").children("h3.title");
//取得子节点h3、class为title

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

Javascript 相关文章推荐
做好七件事帮你提升jQuery的性能
Feb 06 Javascript
javascript随机显示背景图片的方法
Jun 18 Javascript
jquery+css实现动感的图片切换效果
Nov 25 Javascript
jQuery 实现ajax传入参数含有特殊字符的方法总结
Oct 17 Javascript
BootStrap modal模态弹窗使用小结
Oct 26 Javascript
jQuery获取this当前对象子元素对象的方法
Nov 29 Javascript
javascript-解决mongoose数据查询的异步操作
Dec 22 Javascript
微信小程序  checkbox组件详解及简单实例
Jan 10 Javascript
JavaScript作用域、闭包、对象与原型链概念及用法实例总结
Aug 20 Javascript
重学 JS:为啥 await 不能用在 forEach 中详解
Apr 15 Javascript
微信小程序开发(三):返回上一级页面并刷新操作示例【页面栈】
Jun 01 Javascript
JavaScript中的函数式编程详解
Aug 22 Javascript
原生js实现autocomplete插件
Apr 14 #Javascript
jQuery循环遍历子节点并获取值的方法
Apr 14 #Javascript
基于jQuery实现音乐播放试听列表
Apr 14 #Javascript
js仿3366小游戏选字游戏
Apr 14 #Javascript
Javascript实现鼠标框选操作  不是点击选取
Apr 14 #Javascript
Node.js实现数据推送
Apr 14 #Javascript
node.js实现端口转发
Apr 14 #Javascript
You might like
简单的用PHP编写的导航条程序
2006/10/09 PHP
一个可以删除字符串中HTML标记的PHP函数
2006/10/09 PHP
解析PayPal支付接口的PHP开发方式
2010/11/28 PHP
laravel容器延迟加载以及auth扩展详解
2015/03/02 PHP
Yii2 输出xml格式数据的方法
2016/05/03 PHP
CI框架实现框架前后端分离的方法详解
2016/12/30 PHP
JavaScript 设计模式之组合模式解析
2010/04/09 Javascript
jquery 单击li防止重复加载的实现代码
2010/12/24 Javascript
TimergliderJS 一个基于jQuery的时间轴插件
2011/12/07 Javascript
js 调用父窗口的具体实现代码
2013/07/15 Javascript
JavaScript实现cookie的写入、读取、删除功能
2015/11/05 Javascript
解决js函数闭包内存泄露问题的办法
2016/01/25 Javascript
基于AngularJs + Bootstrap + AngularStrap相结合实现省市区联动代码
2016/05/30 Javascript
微信jssdk用法汇总
2016/07/16 Javascript
js实现的光标位置工具函数示例
2016/10/03 Javascript
JS获取当前地理位置的方法
2017/10/25 Javascript
vue中实现移动端的scroll滚动方法
2018/03/03 Javascript
JS中Promise函数then的奥秘探究
2018/07/30 Javascript
解决echarts vue数据更新,视图不更新问题(echarts嵌在vue弹框中)
2020/07/20 Javascript
[04:26]DOTA2上海特锦赛小组赛第二日 TOP10精彩集锦
2016/02/27 DOTA
[34:39]DOTA2上海特级锦标赛主赛事日 - 4 败者组第四轮#1COL VS EG第二局
2016/03/05 DOTA
利用python批量检查网站的可用性
2016/09/09 Python
Python 专题三 字符串的基础知识
2017/03/19 Python
python urllib urlopen()对象方法/代理的补充说明
2017/06/29 Python
python3+PyQt5自定义视图详解
2018/04/24 Python
python numpy格式化打印的实例
2018/05/14 Python
3分钟学会一个Python小技巧
2018/11/23 Python
Django model select的多种用法详解
2019/07/16 Python
聊聊Python pandas 中loc函数的使用,及跟iloc的区别说明
2021/03/03 Python
Expedia挪威官网:酒店、机票和租车
2018/03/03 全球购物
英语专业推荐信
2013/11/16 职场文书
文明教师事迹材料
2014/01/16 职场文书
推广普通话演讲稿
2014/05/23 职场文书
教师党的群众路线教育实践活动剖析材料
2014/10/09 职场文书
雾霾停课通知
2015/04/24 职场文书
shell进度条追踪指令执行时间的场景分析
2022/06/16 Servers