JQuery中parent(),parents(),parentsUntil()区别联系以及使用方法教程
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中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

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

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

在 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 的字符范围更大,并使用专门的函数进行算术运算。

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

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

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

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

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