如何使用 jQuery 检查 HTML 元素是否为空?

问题描述 投票:0回答:19

我尝试仅在 HTML 元素为空时使用 jQuery 调用函数。

类似这样的:

if (isEmpty($('#element'))) {
    // do something
}
javascript jquery
19个回答
633
投票
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 插件,但您明白了。


125
投票

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

if($.trim($("selector").html())=='')

79
投票

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

if ($someElement.children().length == 0){
     someAction();
}

29
投票
!elt.hasChildNodes()

是的,我知道,这不是 jQuery,所以你可以使用这个:

!$(elt)[0].hasChildNodes()

现在快乐吗?


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

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

13
投票

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

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

11
投票

在resume中,有很多选项可以判断某个元素是否为空:

1- 使用

html
:

if (!$.trim($('p#element').html())) {
    // paragraph with id="element" is empty, your code goes here
}

2- 使用

text
:

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- 使用

length

if (!$('p#element').length){
    // paragraph with id="element" is empty, your code goes here
}

如果你想知道输入元素是否为空,你可以使用

val
:

if (!$.trim($('input#element').val())) {
    // input with id="element" is empty, your code goes here
}

8
投票

空如不包含任何文字?

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

2
投票

html()
children()
相比,浏览器需要更少“工作”的另一个选项:

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

1
投票

你可以尝试:

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

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


1
投票
document.getElementById("id").innerHTML == "" || null

$("element").html() == "" || null

1
投票

普通的 JavaScript 解决方案:

if(document.querySelector('#element:empty')) {
  //element is empty
}

请记住,空格会影响空,但注释不会。有关更多信息,请查看 MDN 关于 空伪类


0
投票

我看到另一位贡献者提到了这一点,我想强调一下。最好和最短的解决方案是;

 if($('#element:empty')){ do something }

-1
投票
if($("#element").html() === "")
{

}

-1
投票

您在寻找

jQuery.isEmptyObject()
吗?

http://api.jquery.com/jquery.isemptyobject/


-1
投票

这是一个基于 https://stackoverflow.com/a/6813294/698289

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

-1
投票

JavaScript

var el= document.querySelector('body'); 
console.log(el);
console.log('Empty : '+ isEmptyTag(el));
console.log('Having Children : '+ hasChildren(el));


function isEmptyTag(tag) { 
    return (tag.innerHTML.trim() === '') ? true : false ;
}
function hasChildren(tag) {
    //return (tag.childElementCount !== 0) ? true : false ; // Not For IE
    //return (tag.childNodes.length !== 0) ? true : false ; // Including Comments
    return (tag.children.length !== 0) ? true : false ; // Only Elements
}

尝试使用其中任何一个!

document.getElementsByTagName('div')[0];
document.getElementsByClassName('topbar')[0];

document.querySelectorAll('div')[0];
document.querySelector('div'); // gets the first element.
​

-1
投票

试试这个:

if (!$('#el').html()) {
    ...
}

-2
投票

换行符被视为 FF 中元素的内容。

<div>
</div>
<div></div>

例如:

$("div:empty").text("Empty").css('background', '#ff0000');

在 IE 中,两个 div 都被认为是空的,在 FF 和 Chrome 中,只有最后一个是空的。

您可以使用@qwertymk提供的解决方案

if(!/[\S]/.test($('#element').html())) { // for one element
    alert('empty');
}

$('.elements').each(function(){  // for many elements
    if(!/[\S]/.test($(this).html())) { 
        // is empty
    }
})
© www.soinside.com 2019 - 2024. All rights reserved.