我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。
就像这样:
if (isEmpty($('#element'))) {
// do something
}
我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。
就像这样:
if (isEmpty($('#element'))) {
// do something
}
当前回答
空格和换行符是使用:empty选择器的主要问题。注意,在CSS中:empty伪类的行为与此相同。我喜欢这个方法:
if ($someElement.children().length == 0){
someAction();
}
其他回答
你在找jQuery.isEmptyObject()吗?
http://api.jquery.com/jquery.isemptyobject/
在resume中,有很多选项可以判断一个元素是否为空:
1-使用html:
if (!$.trim($('p#element').html())) {
// paragraph with id="element" is empty, your code goes here
}
2-使用文本:
if (!$.trim($('p#element').text())) {
// paragraph with id="element" is empty, your code goes here
}
3-使用is(':empty'):
if ($('p#element').is(':empty')) {
// paragraph with id="element" is empty, your code goes here
}
4-使用长度
if (!$('p#element').length){
// paragraph with id="element" is empty, your code goes here
}
在addiction中,如果你想知道输入元素是否为空,可以使用val:
if (!$.trim($('input#element').val())) {
// input with id="element" is empty, your code goes here
}
下面是一个基于https://stackoverflow.com/a/6813294/698289的jQuery过滤器
$.extend($.expr[':'], {
trimmedEmpty: function(el) {
return !$.trim($(el).html());
}
});
我发现这是唯一可靠的方法(因为Chrome和FF认为空格和换行符作为元素):
if($.trim($("selector").html())=='')
如果你说的“空”是指没有HTML内容,
if($('#element').html() == "") {
//call function
}