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

就像这样:

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

当前回答

在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());
  }
});

空格和换行符是使用:empty选择器的主要问题。注意,在CSS中:empty伪类的行为与此相同。我喜欢这个方法:

if ($someElement.children().length == 0){
     someAction();
}
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插件,但你知道的。

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

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

}