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

就像这样:

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

当前回答

jQuery.fn.doSomething = function() {
   //return something with 'this'
};

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

其他回答

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 (!$('#element').text().length) {
    ...
}

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

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

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

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

你可以试试:

if($('selector').html().toString().replace(/ /g,'') == "") {
//code here
}

*替换空格,以防万一;)