Drukowana wersja tematu

Kliknij tu, aby zobaczyć temat w orginalnym formacie

Forum PHP.pl _ JavaScript _ onClick przypisane do label z checkboxem wywołuje się dwa razy

Napisany przez: sabat24 28.04.2018, 13:32:42

Kod HTML wygląda tak:

  1. <http://december.com/html/4/element/label.html>
  2. kliknij tu
  3. <http://december.com/html/4/element/input.html name="a" value="1" autocomplete="off" type="checkbox">
  4. </http://december.com/html/4/element/label.html>


JS mam następujący:

  1. $(function() {
  2. $('label').on('click', function() {
  3. alert('click');
  4. });
  5. });


Całość dostępna tutaj -> https://jsfiddle.net/pppxenfb/

Po kliknięciu w napis: kliknij tu, alert wyskakuje dwa razy. Drugim razem zapewne jak checkbox się zaznaczy / odznaczy. Jak można przypisać w takim razie do takiego labela, tylko jedno zdarzenie, zakładając, że nie chcę zmieniać struktury z użyciem "for" oraz ID.

Napisany przez: trueblue 28.04.2018, 13:48:38

  1. $('label input').on('click', function(e) {
  2. e.stopPropagation();
  3. });
  4. $('label').on('click', function() {
  5. alert('click');
  6. });

Możesz wyjaśnić jaki cel chcesz osiągnąć?

Napisany przez: sabat24 28.04.2018, 13:58:50

Próbowałem tak, ale wtedy domyślnie nie zaznacza mi checkboxa. Zapewne dałoby się to obejść przez $(this).find('input').prop('checked', true); tylko wtedy sens wrapowania tego labelem zniknąłby.

Edited: Powyższe dotyczyło kodu sprzed Twojej edycji.

Co do celowości. Odziedziczyłem kod, w którym label ma jeszcze 2 potomków i są to elementy <img>, a input jest ukryty. Jest to więc forma checkboxa zastąpionego obrazkami. Kliknięcie na label miało zaznaczać checkboxa, by następnie wysłany formularz zawierał odpowiednie elementy. Dodatkowo onClick, miał powodować dodatkowe zaznaczanie i odnzaczanie innych elementów.

Tyle, że własnie pisząc Ci odpowiedź, uświadomiłem sobie, że to zostało zrobione bezsensu. Zdarzenie, które teraz jest przypięte do onclick, powinno zostać zmienione do onChange inputa i wszystko powinno działać poprawnie.

Napisany przez: trueblue 28.04.2018, 14:15:03

Bardzo możliwe, że można to osiągnąć poprzez tzw. checkbox hack, dlatego pytałem.
https://css-tricks.com/almanac/selectors/c/checked/

Napisany przez: sabat24 28.04.2018, 14:23:28

Myślałem o tym i jeśli chodzi o sam fakt zmiany obrazka, tak byłoby najlepiej, gdyby to było zrobione. Aczkolwiek wykonywane są jeszcze dodatkowe sprawdzenia w samym JS, więc i tak się nie obejdzie bez dodatkowego kodu. Przerzucenie zdarzenia na change inputa załatwiło sprawę. W każdym razie dzięki za pomoc, bo sobie uświadomiłem w czym leży problem.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)