jQuery   发布时间:2022-03-30  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Jquery获取包含具有特定html值的子元素的元素大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我想使用 Jquery添加一个类到“li”元素,其中包含一个html / val等于零的“span”元素.

例如,如果我的代码如下所示:

<ul>
    <li><span>Item 1</span><span class="num">30</span></li>
    <li><span>Item 2</span><span class="num">0</span></li>
    <li><span>Item 3</span><span class="num">20</span></li>
</ul>

我想将其更改为以下内容

<ul>
    <li><span>Item 1</span><span class="num">30</span></li>
    <li class="disabled"><span>Item 2</span><span class="num">0</span></li>
    <li><span>Item 3</span><span class="num">20</span></li>
</ul>

过去我已经使用代码检查元素属性值,但是从来没有使用html / val来做这个事情呢?

$('li').has('span.num').addClass('disabled');

但是在这种情况下会导致:

<ul>
    <li class="disabled"><span>Item 1</span><span class="num">30</span></li>
    <li class="disabled"><span>Item 2</span><span class="num">0</span></li>
    <li class="disabled"><span>Item 3</span><span class="num">20</span></li>
</ul>

这显然是不会工作…谢谢

解决方法

这应该做你想要的
$('li').each(function(){
    if( $(this).find('span.num').text() == '0' ) $(this).addClass('disabled')
});

JS Fiddle

我会建议如下:

$('li').has('span.num:contains(0)').addClass('disabled')

但是它不起作用,因为它检查该值是否存在于html内,而不是完全匹配.在这种情况下,每个span.num元素都有一个0,所以每个li都会得到所选的类.似乎没有:equals()对应于:contains()选择器.

大佬总结

以上是大佬教程为你收集整理的Jquery获取包含具有特定html值的子元素的元素全部内容,希望文章能够帮你解决Jquery获取包含具有特定html值的子元素的元素所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。