首页 web前端 js教程 JQuery中parent(),parents(),parentsUntil()区别联系以及使用方法教程

JQuery中parent(),parents(),parentsUntil()区别联系以及使用方法教程

Jun 24, 2017 am 09:28 AM
jquery parent 区别

parent()其实很简单, 就是指定选择器中每个元素的外边的一层。比如$("p"),那么就是结果就是包裹着

的数据 如:

。如果有多个

则结果集为对象集。可以用eq(i),first(),last()定位。如果数据为

  • 怎使用$("p").parent("li")查询的结果为空,因为

    的外层为

    JQuery手册中

    <p><p>Hello</p></p><p class="selected"><p>Hello Again</p></p>
    登录后复制
    <pre class="brush:php;toolbar:false">$("p").parent(".selected");
    登录后复制
    //结果:
    登录后复制
    [ <p class="selected"><p>Hello Again</p></p> ]
    登录后复制

    可以理解为

    $("p").parent().find(".selected");
    登录后复制

    找直接父亲中类为selected的那一个或者几个。

    所以parent()的实用性并不强。

    parents()就是选择器中每个元素的所有的父亲,如果选择器有多个父亲则返回的是个结果集。结果集的结果是由内层向外层排列的。最外层就是整个html元素了,第一个就是紧包着选择器中每个元素的元素。结果集中并没有重复的元素。

    同理当带参数时,也是在结果集中find制定的元素

    $("p").parents(".selected");
    登录后复制
    $("p").parents().find(".selected");
    登录后复制

    因此我们想找到选择器的某个父亲,就要先找到他的所有父亲,然后在find这个父亲。

    当我们想找到当前元素的某个父亲的时候,下面的语法就要用到了。

    $(this).parents("li");//$(this).parents().find("li");
    登录后复制

    所以parents()的实用性很强。非常常用。

    parentsUntil(expr)。如果说parents()是在整个html元素中找选择器中每个元素的所有父亲,那么parentsUntil()的作用就是限制了查找的范围。这个范围就是 $(expr).html()

    $("p").parents();//包含整个html 元素$("p").parentsUntil("html");//不包含整个html元素
    登录后复制

    以上两个表达式的结果集只相差一个元素,就是整个html元素。

    $("p").parents();//包含整个html 元素$("p").parentsUntil();//包含整个html元素
    登录后复制

    当parentsUntil()不带参数时,他等同于parents();

    parentsUntil(expr)的结果集中的结果同样是由内层向外层排列的。parentUntil(expr),会从第一个包裹着元素父元素开始向外逐层查找,直到遇到第一个与表达式(expr)相匹配的元素为止。

    $("p").parentsUntil(expr);
    登录后复制

    相当于在$(expr)中由内之外的寻找$("p")中每个元素的所有父元素

    为了更加精准的寻找到指定的元素,可以如下的使用。

    $("p").parentsUntil("ul").find("li");
    登录后复制

    但以上做法不能找到ul>li,只能找到ul * li。因为paentsUntil()返回结果集中最大的父亲是ul>*而find是在ul>*的后代元素查找不包括ul>*的元素。所以如果用该方法查找ul>li是不可行的

    可以使用以下代码查询全部ul下的li(第一行),最近的ul下的所有li(第二行)

    $("p").parents("ul").find("li");$("p").parents("ul").eq(0).find("li");
    登录后复制

    parentsUntil(expr),返回的结果集不包括expr本身,而后面如果使用find()又会在结果集后代元素中查询,所以查询得到的结果不是expr的子元素而是二代和二代以后的子元素。

    鉴于parentsUntil的表现,一般不建议使用。

    parnetsUntil()可用于找到某个模块下的某些元素。

    当我们要具体对结果集中某个元素进行操作是,要记得使用eq(i),first(),last()等函数取值,不然操作的是整个结果集。

    动态查找父节点

    $(this).parent("li");//找到第一个包住$(this)的dom,如这个dom是li则返回他的对象,如果不是则返回空对象$(this).parents("li");//找到所有$(this)的父亲,并在其中找出所有的li的对象,组成结果集。结果集中结果由内之外排列$(this).parents().find("li");//同上。$(this).parents("li").eq(0);//$(this)外第一个包裹他的li对象$(this).parentsUntil("li");//$(this)外到第一个包裹他的li之内的所有的$(this)的父亲$(this).parentsUntil("ul").find("li");//$(this)在ul之前的那个父亲之内(不包括该父亲)找所有的li;如果<ul><li><p><a onclick="f()">中a是this的话,那么相当于$("li").find("li");最后结果之空。$(this).parents("li").sublings();//查找所在的li的所有同辈元素
    登录后复制

    与parent()对应的函数是children()

    与parents()对应的函数是find()

    以上是JQuery中parent(),parents(),parentsUntil()区别联系以及使用方法教程的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

c#多线程和异步的区别 c#多线程和异步的区别 Apr 03, 2025 pm 02:57 PM

多线程和异步的区别在于,多线程同时执行多个线程,而异步在不阻塞当前线程的情况下执行操作。多线程用于计算密集型任务,而异步用于用户交互操作。多线程的优势是提高计算性能,异步的优势是不阻塞 UI 线程。选择多线程还是异步取决于任务性质:计算密集型任务使用多线程,与外部资源交互且需要保持 UI 响应的任务使用异步。

C语言 sum 的作用是什么? C语言 sum 的作用是什么? Apr 03, 2025 pm 02:21 PM

C语言中没有内置求和函数,需自行编写。可通过遍历数组并累加元素实现求和:循环版本:使用for循环和数组长度计算求和。指针版本:使用指针指向数组元素,通过自增指针遍历高效求和。动态分配数组版本:动态分配数组并自行管理内存,确保释放已分配内存以防止内存泄漏。

char与wchar_t在C语言中的区别 char与wchar_t在C语言中的区别 Apr 03, 2025 pm 03:09 PM

在 C 语言中,char 和 wchar_t 的主要区别在于字符编码:char 使用 ASCII 或扩展 ASCII,wchar_t 使用 Unicode;char 占用 1-2 个字节,wchar_t 占用 2-4 个字节;char 适用于英语文本,wchar_t 适用于多语言文本;char 广泛支持,wchar_t 依赖于编译器和操作系统是否支持 Unicode;char 的字符范围受限,wchar_t 的字符范围更大,并使用专门的函数进行算术运算。

有什么手机APP可以将XML转换成PDF? 有什么手机APP可以将XML转换成PDF? Apr 02, 2025 pm 08:54 PM

无法找到一款将 XML 直接转换为 PDF 的应用程序,因为它们是两种根本不同的格式。XML 用于存储数据,而 PDF 用于显示文档。要完成转换,可以使用编程语言和库,例如 Python 和 ReportLab,来解析 XML 数据并生成 PDF 文档。

c语言函数的基本要求有哪些 c语言函数的基本要求有哪些 Apr 03, 2025 pm 10:06 PM

C语言函数是代码模块化和程序搭建的基础。它们由声明(函数头)和定义(函数体)组成。C语言默认使用值传递参数,但也可使用地址传递修改外部变量。函数可以有返回值或无返回值,返回值类型必须与声明一致。函数命名应清晰易懂,使用驼峰或下划线命名法。遵循单一职责原则,保持函数简洁性,以提高可维护性和可读性。

Go语言中`var`和`type`关键字定义结构体的区别是什么? Go语言中`var`和`type`关键字定义结构体的区别是什么? Apr 02, 2025 pm 12:57 PM

Go语言中结构体定义的两种方式:var与type关键字的差异Go语言在定义结构体时,经常会看到两种不同的写法:一�...

JavaScript中如何从指定DOM节点下使用XPath进行查找? JavaScript中如何从指定DOM节点下使用XPath进行查找? Apr 04, 2025 pm 11:15 PM

DOM节点下XPath查找方法详解在JavaScript中,我们经常需要根据XPath表达式从DOM树中查找特定的节点。如果需要从某�...

以太币和比特币的区别 以太币和比特币区别是什么 以太币和比特币的区别 以太币和比特币区别是什么 Mar 19, 2025 pm 04:54 PM

以太币与比特币区别显着。技术上,比特币用 PoW,以太币从 PoW 转向 PoS 。交易速度比特币慢,以太币快。应用场景里,比特币侧重支付存储,以太币支撑智能合约与 DApp 。发行上,比特币总量 2100 万枚,以太币无固定总量。安全方面各有挑战。市场价值上,比特币市值居首,两者价格波动都大,但因特性不同,以太币价格走势有独特之处 。

See all articles