首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何检查jQuery查找返回true或false?

如何检查jQuery查找返回true或false?
EN

Stack Overflow用户
提问于 2014-12-25 18:55:00
回答 6查看 49.8K关注 0票数 39

HTML代码

代码语言:javascript
复制
<div class="parent1">
    <div class="child1">Child1</div>
    <div class="child2">Child2</div>
    <div class="child3">Child3</div>
</div>

<div class="parent2">
    <div class="child1">Child1</div>
    <div class="child2">Child2</div>
</div>

jQuery代码

代码语言:javascript
复制
alert($(".parent1").find(".child3").text());
alert($(".parent2").find(".child3").text());

我的问题是如何检查find函数返回true或false?

在上面代码中,它返回空值,其中parent1类有child3类,而parent2类没有child3类。

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2014-12-25 18:57:29

你不能在if条件下只使用find。您可以使用has或检查length属性。

代码语言:javascript
复制
var elm = $('.parent1');
if(elm.has('.child3')){
   var child3 = elm.find('.child3');
}

或者简单地像这样

代码语言:javascript
复制
var child3 = $('.parent1').find(".child3");
if(child3.length > 0) {
  // child3 is present
}
票数 43
EN

Stack Overflow用户

发布于 2014-12-25 18:58:37

您可以使用.length属性来检查元素是否存在。

代码语言:javascript
复制
var elem = $(".parent2").find(".child3");
if(elem.length){
    alert(elem.text());
}else{
    alert('Element doesnt exists')
}

或者,您可以使用.has()

代码语言:javascript
复制
var elem = $(".parent2");
if(elem.has(".child3")){
    alert(elem.find(".child3").text());
}else{
    alert('Element doesnt exists')
}
票数 7
EN

Stack Overflow用户

发布于 2014-12-25 18:58:54

无论何时在$()中包装选择器,它都会返回一个包含匹配元素数组的jQuery对象。

因此,您可以使用length属性来测试是否存在匹配项

代码语言:javascript
复制
var $collection = $(".parent2").find(".child3").length;
if ($collection.length)....

您还可以使用其他方法,如is()

代码语言:javascript
复制
var #collection = $(".parent2");
if($collection.children().is(".child3") /* returns tru if there are matches
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27646559

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档