我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。
就像这样:
if (isEmpty($('#element'))) {
// do something
}
我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。
就像这样:
if (isEmpty($('#element'))) {
// do something
}
当前回答
if ($('#element').is(':empty')){
//do something
}
更多信息请参见http://api.jquery.com/is/和http://api.jquery.com/empty-selector/
编辑:
正如一些人指出的那样,浏览器对空元素的解释可能会有所不同。如果你想忽略不可见的元素,如空格和换行符,并使实现更加一致,你可以创建一个函数(或只使用它里面的代码)。
function isEmpty( el ){
return !$.trim(el.html())
}
if (isEmpty($('#element'))) {
// do something
}
你也可以把它变成一个jQuery插件,但你知道的。
其他回答
你可以试试:
if($('selector').html().toString().replace(/ /g,'') == "") {
//code here
}
*替换空格,以防万一;)
我发现这是唯一可靠的方法(因为Chrome和FF认为空格和换行符作为元素):
if($.trim($("selector").html())=='')
!elt.hasChildNodes()
是的,我知道,这不是jQuery,所以你可以使用这个:
!$(elt)[0].hasChildNodes()
现在快乐吗?
空格和换行符是使用:empty选择器的主要问题。注意,在CSS中:empty伪类的行为与此相同。我喜欢这个方法:
if ($someElement.children().length == 0){
someAction();
}
如果你说的“空”是指没有HTML内容,
if($('#element').html() == "") {
//call function
}