我试图调用一个函数,只有当一个HTML元素是空的,使用jQuery。

就像这样:

if (isEmpty($('#element'))) {
    // do something
}

当前回答

如果你说的“空”是指没有HTML内容,

if($('#element').html() == "") {
  //call function
}

其他回答

下面是一个基于https://stackoverflow.com/a/6813294/698289的jQuery过滤器

$.extend($.expr[':'], {
  trimmedEmpty: function(el) {
    return !$.trim($(el).html());
  }
});

空是指不包含文本吗?

if (!$('#element').text().length) {
    ...
}

对于浏览器来说,另一个选项应该比html()或children()要求更少的“工作”:

function isEmpty( el ){
  return !el.has('*').length;
}

我发现这是唯一可靠的方法(因为Chrome和FF认为空格和换行符作为元素):

if($.trim($("selector").html())=='')
jQuery.fn.doSomething = function() {
   //return something with 'this'
};

$('selector:empty').doSomething();