Odpowiedzi:
if ($('#element').is(':empty')){
//do something
}
Aby uzyskać więcej informacji, zobacz http://api.jquery.com/is/ i http://api.jquery.com/empty-selector/
EDYTOWAĆ:
Jak niektórzy wskazywali, interpretacja pustego elementu w przeglądarce może się różnić. Jeśli chcesz zignorować niewidoczne elementy, takie jak spacje i podziały wierszy, i uczynić implementację bardziej spójną, możesz utworzyć funkcję (lub po prostu użyć kodu w niej zawartego).
function isEmpty( el ){
return !$.trim(el.html())
}
if (isEmpty($('#element'))) {
// do something
}
Możesz także zrobić z niego wtyczkę jQuery, ale masz pomysł.
Uważam, że jest to jedyny niezawodny sposób (ponieważ Chrome i FF uważają białe spacje i łamanie linii za elementy):
if($.trim($("selector").html())=='')
if(!$.trim($("selector").html())
if($("selector").children().length === 0)lub if($("selector > *").length === 0).
Białe spacje i podziały linii to główne problemy z używaniem: pustego selektora. Ostrożnie, w CSS pseudo-klasa: pusta zachowuje się w ten sam sposób. Podoba mi się ta metoda:
if ($someElement.children().length == 0){
someAction();
}
$.children()nie zwraca tekstowych lub komentarz węzłów, co oznacza tylko to rozwiązanie jest elementem kontroli jest pusty elementów . Jeśli element, który zawiera tylko tekst lub komentarze, nie powinien być uważany za pusty dla twoich potrzeb, powinieneś użyć jednego z innych rozwiązań.
selectelementów jest idealny. warunek może być również if(! $el.children().length).
!elt.hasChildNodes()
Tak, wiem, to nie jest jQuery, więc możesz użyć tego:
!$(elt)[0].hasChildNodes()
Szczęśliwa teraz?
filterfunkcji jQuery, ponieważ nie chciałem używać jQuery wewnątrz funkcji, chyba że jest to konieczne.
<div class="results"> </div>, to instrukcja zwróci false. jsfiddle.net/ytliuSVN/0pdwLt46
jQuery.fn.doSomething = function() {
//return something with 'this'
};
$('selector:empty').doSomething();
thiselement jQuery @ZealMurapa?
Jeśli przez „pusty” masz na myśli brak treści HTML,
if($('#element').html() == "") {
//call function
}
Pusty jak w nie zawiera tekstu?
if (!$('#element').text().length) {
...
}
W CV można znaleźć wiele opcji, aby sprawdzić, czy element jest pusty:
1- Korzystanie html:
if (!$.trim($('p#element').html())) {
// paragraph with id="element" is empty, your code goes here
}
2- Korzystanie text:
if (!$.trim($('p#element').text())) {
// paragraph with id="element" is empty, your code goes here
}
3- Korzystanie is(':empty'):
if ($('p#element').is(':empty')) {
// paragraph with id="element" is empty, your code goes here
}
4- Korzystanie length
if (!$('p#element').length){
// paragraph with id="element" is empty, your code goes here
}
Nałogowo, jeśli próbujesz dowiedzieć się, czy element wejściowy jest pusty, możesz użyć val:
if (!$.trim($('input#element').val())) {
// input with id="element" is empty, your code goes here
}
document.getElementById("id").innerHTML == "" || null
lub
$("element").html() == "" || null
Możesz spróbować:
if($('selector').html().toString().replace(/ /g,'') == "") {
//code here
}
* Zamień białe spacje, po prostu wstaw;)
!/[\S]/.test($('Selector').html())działałoby to lepiej, gdy znajdziesz trochę białych znaków, wiesz, że nie jest pusty
The production CharacterClassEscape :: S evaluates by returning the set of all characters not included in the set returned by CharacterClassEscape :: s.z ecma-international.org/ecma-262/5.1/#sec-15.10.2.12
Szukasz jQuery.isEmptyObject()?
Oto filtr jQuery oparty na https://stackoverflow.com/a/6813294/698289
$.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
}
spróbuj użyć dowolnego z tego!
document.getElementsByTagName('div')[0];
document.getElementsByClassName('topbar')[0];
document.querySelectorAll('div')[0];
document.querySelector('div'); // gets the first element.
Podziały linii są traktowane jako zawartość elementów w FF.
<div>
</div>
<div></div>
Dawny:
$("div:empty").text("Empty").css('background', '#ff0000');
W IE oba div są uważane za puste, w FF i Chrome tylko ostatni jest pusty.
Możesz skorzystać z rozwiązania dostarczonego przez @qwertymk
if(!/[\S]/.test($('#element').html())) { // for one element
alert('empty');
}
lub
$('.elements').each(function(){ // for many elements
if(!/[\S]/.test($(this).html())) {
// is empty
}
})
$('#elem').text().match(/\S/) || alert('empty');