Risposte:
if ($('#element').is(':empty')){
//do something
}
per maggiori informazioni consultare http://api.jquery.com/is/ e http://api.jquery.com/empty-selector/
MODIFICARE:
Come alcuni hanno sottolineato, l'interpretazione del browser di un elemento vuoto può variare. Se desideri ignorare elementi invisibili come spazi e interruzioni di riga e rendere l'implementazione più coerente, puoi creare una funzione (o semplicemente usare il codice al suo interno).
function isEmpty( el ){
return !$.trim(el.html())
}
if (isEmpty($('#element'))) {
// do something
}
Puoi anche trasformarlo in un plugin jQuery, ma hai l'idea.
Ho trovato questo l'unico modo affidabile (dal momento che Chrome e FF considerano gli spazi bianchi e le interruzioni di riga come elementi):
if($.trim($("selector").html())=='')
if(!$.trim($("selector").html())
if($("selector").children().length === 0)
o if($("selector > *").length === 0)
.
Spazi vuoti e interruzioni di riga sono i problemi principali relativi all'utilizzo di: selettore vuoto. Attenzione, nei CSS la pseudo classe: vuota si comporta allo stesso modo. Mi piace questo metodo:
if ($someElement.children().length == 0){
someAction();
}
$.children()
non restituisce nodi di testo o di commento, il che significa che questa soluzione verifica solo se l'elemento è vuoto di elementi . Se un elemento che contiene solo testo o commenti non deve essere considerato vuoto per le tue esigenze, allora dovresti usare una delle altre soluzioni.
select
elements è perfetto. la condizione può anche essere if(! $el.children().length)
.
!elt.hasChildNodes()
Sì, lo so, questo non è jQuery, quindi puoi usare questo:
!$(elt)[0].hasChildNodes()
Felice adesso?
filter
funzione jQuery poiché non volevo usare jQuery all'interno della funzione a meno che non fosse necessario.
<div class="results"> </div>
, questa affermazione restituirà false. jsfiddle.net/ytliuSVN/0pdwLt46
jQuery.fn.doSomething = function() {
//return something with 'this'
};
$('selector:empty').doSomething();
this
oltre all'elemento jQuery @ZealMurapa?
Se per "vuoto" intendi senza contenuto HTML,
if($('#element').html() == "") {
//call function
}
Vuoto come in non contiene testo?
if (!$('#element').text().length) {
...
}
Nel riassunto, ci sono molte opzioni per scoprire se un elemento è vuoto:
1- Utilizzo html
:
if (!$.trim($('p#element').html())) {
// paragraph with id="element" is empty, your code goes here
}
2- Utilizzo text
:
if (!$.trim($('p#element').text())) {
// paragraph with id="element" is empty, your code goes here
}
3- Utilizzo is(':empty')
:
if ($('p#element').is(':empty')) {
// paragraph with id="element" is empty, your code goes here
}
4- Utilizzo length
if (!$('p#element').length){
// paragraph with id="element" is empty, your code goes here
}
Inoltre, se stai cercando di scoprire se un elemento di input è vuoto, puoi utilizzare val
:
if (!$.trim($('input#element').val())) {
// input with id="element" is empty, your code goes here
}
document.getElementById("id").innerHTML == "" || null
o
$("element").html() == "" || null
Puoi provare:
if($('selector').html().toString().replace(/ /g,'') == "") {
//code here
}
* Sostituisci gli spazi bianchi, basta inserire;)
!/[\S]/.test($('Selector').html())
funzionerebbe meglio, una volta trovato uno spazio bianco sai che non è vuoto
The production CharacterClassEscape :: S evaluates by returning the set of all characters not included in the set returned by CharacterClassEscape :: s.
da ecma-international.org/ecma-262/5.1/#sec-15.10.2.12
Stai cercando jQuery.isEmptyObject()
?
Ecco un filtro jQuery basato su 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
}
prova a usare uno di questi!
document.getElementsByTagName('div')[0];
document.getElementsByClassName('topbar')[0];
document.querySelectorAll('div')[0];
document.querySelector('div'); // gets the first element.
Le interruzioni di riga sono considerate come contenuto di elementi in FF.
<div>
</div>
<div></div>
Ex:
$("div:empty").text("Empty").css('background', '#ff0000');
In IE entrambi i div sono considerati vuoti, in FF un Chrome è vuoto solo l'ultimo.
È possibile utilizzare la soluzione fornita da @qwertymk
if(!/[\S]/.test($('#element').html())) { // for one element
alert('empty');
}
o
$('.elements').each(function(){ // for many elements
if(!/[\S]/.test($(this).html())) {
// is empty
}
})
$('#elem').text().match(/\S/) || alert('empty');