我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。
就像这样:
if (isEmpty($('#element'))) {
// do something
}
我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。
就像这样:
if (isEmpty($('#element'))) {
// do something
}
当前回答
如果你说的“空”是指没有HTML内容,
if($('#element').html() == "") {
//call function
}
其他回答
jQuery.fn.doSomething = function() {
//return something with 'this'
};
$('selector:empty').doSomething();
下面是一个基于https://stackoverflow.com/a/6813294/698289的jQuery过滤器
$.extend($.expr[':'], {
trimmedEmpty: function(el) {
return !$.trim($(el).html());
}
});
如果你说的“空”是指没有HTML内容,
if($('#element').html() == "") {
//call function
}
换行符被认为是FF中元素的内容。
<div>
</div>
<div></div>
Ex:
$("div:empty").text("Empty").css('background', '#ff0000');
在IE中,两个div都被认为是空的,在FF和Chrome中,只有最后一个是空的。
您可以使用@qwertymk提供的解决方案
if(!/[\S]/.test($('#element').html())) { // for one element
alert('empty');
}
or
$('.elements').each(function(){ // for many elements
if(!/[\S]/.test($(this).html())) {
// is empty
}
})
我发现这是唯一可靠的方法(因为Chrome和FF认为空格和换行符作为元素):
if($.trim($("selector").html())=='')