Answers:
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插件,但您知道了。
我发现这是唯一可靠的方法(因为Chrome和FF将空格和换行符视为元素):
if($.trim($("selector").html())=='')
if(!$.trim($("selector").html())
if($("selector").children().length === 0)
或if($("selector > *").length === 0)
。
空格和换行符是使用:empty选择器的主要问题。小心,在CSS中:empty伪类的行为方式相同。我喜欢这种方法:
if ($someElement.children().length == 0){
someAction();
}
$.children()
不返回文本或注释节点,这意味着该解决方案只检查是该元素为空的元素。如果仅包含文本或注释的元素不应该被认为是空的,那么您应该使用其他解决方案之一。
select
元素是完美的。条件也可以if(! $el.children().length)
。
!elt.hasChildNodes()
是的,我知道,这不是jQuery,因此您可以使用以下代码:
!$(elt)[0].hasChildNodes()
现在开心?
filter
函数内使用了您的方法,因为除非有必要,否则我不想在该函数内使用jQuery。
<div class="results"> </div>
,则此语句将返回false。jsfiddle.net/ytliuSVN/0pdwLt46
jQuery.fn.doSomething = function() {
//return something with 'this'
};
$('selector:empty').doSomething();
this
是除了jQuery的元素@ZealMurapa?
为空,如无文字?
if (!$('#element').text().length) {
...
}
在履历表中,有许多选项可以找出元素是否为空:
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
}
你可以试试:
if($('selector').html().toString().replace(/ /g,'') == "") {
//code here
}
*替换空格,以防万一;)
!/[\S]/.test($('Selector').html())
更好地工作,一旦你发现一些空白,你知道它不是空
The production CharacterClassEscape :: S evaluates by returning the set of all characters not included in the set returned by CharacterClassEscape :: s.
来自ecma-international.org/ecma-262/5.1/#sec-15.10.2.12
这是一个基于https://stackoverflow.com/a/6813294/698289的jQuery过滤器
$.extend($.expr[':'], {
trimmedEmpty: function(el) {
return !$.trim($(el).html());
}
});
的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.
换行符被视为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
}
})
$('#elem').text().match(/\S/) || alert('empty');