Perché il mio evento click è stato attivato due volte in jQuery?Perché il mio evento click è stato chiamato due volte in jQuery?
HTML
<ul class=submenu>
<li><label for=toggle><input id=toggle type=checkbox checked>Show</label></li>
</ul>
Javascript
$("ul.submenu li:contains('Show')").on("click", function(e) {
console.log("toggle");
if ($(this).find("[type=checkbox]").is(":checked")) console.log("Show");
else console.log("Hide");
});
Questo è ciò che ottengo in consolle:
toggle menu.js:39
Show menu.js:40
toggle menu.js:39
Hide menu.js:41
> $("ul.submenu li:contains('Show')")
[<li> ]
<label for="toggle">
<input id="toggle" type="checkbox" checked>
"Show"
</label>
</li>
Si attiva solo una volta quando provo qui http://jsfiddle.net/LRjUc/ –
@DominicGreen: Dipende dal fatto che si Fai clic sull'etichetta o sulla casella di controllo (o su 'li'). Se fai clic sull'etichetta, almeno su Chrome, ottieni entrambi gli eventi. –
Sì, è un po 'difficile da vedere, ma se si seleziona l'ultimo testo sulla console, è possibile vedere l'evento sparato due volte dopo. – shuji