• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Sprawdzenie checkboxów (checked) dla więcej niż jednego pytania (ANKIETA)

Object Storage Arubacloud
0 głosów
196 wizyt
pytanie zadane 17 sierpnia 2017 w JavaScript przez Adiks Nowicjusz (240 p.)

Jesteście w stanie podpowiedzieć dlaczego się tak dzieje, że gdy sprawdzam zaznaczenie checkboxów o takim samym id, będących wewnątrz tego samego div'a, to gdy mam tylko jednego checkboxa jest wszystko ok, natomiast gdy dołożę kolejne checkboxy, to nie działa (nie wyświetla alertu)?  

https://codepen.io/anon/pen/KvZowy

 

<form name="a" method="post" action="zapisz.html">
 
<div class="6"> <!-- pytanie nr 6 -->
    <h1>6. Co lubisz jeść?</h1>                 
    <input type="checkbox" id="checkagree" value="1"/>Schabowy<br/>
    <input type="checkbox" id="checkagree" value="2"/>Kebab<br/>
    <input type="checkbox" id="checkagree" value="3"/>Frytki
</div>
<input type="submit" value="Submit" onclick="sprawdz();" />
</form>

function sprawdz(){
 
if(a.checkagree.checked == false)
{
    alert('Wybierz co najmniej 1, maksymalnie 2 dania!');
    return false;
}
return true;
}

 

komentarz 17 sierpnia 2017 przez ScriptyChris Mędrzec (190,190 p.)
if(a.checkagree.checked == false)

Nie dobieraj się w ten sposób do HTMLa. Wystarczy, że omyłkowo w kodzie w wyższym lub tym samym scope zadeklarujesz zmienną o tej samie nazwie (mam na myśli 'a'), a wtedy Twój if nie zadziała. Pobierz formularz poprzez ID lub inny atrybut jako obiekt DOM i dopiero wtedy sprawdzaj jego składowe.

Kontrolki forma możesz sobie pobrać taką funkcyjką:

function getFormControls( formReference ) {
  const formElements = [...formReference.elements];
  const controls = formElements.filter( ( ctrl ) => {
    return ctrl.getAttribute( 'name' );
  } );
  
  return controls;
}

const form = document.querySelector( '[name="testForm"]' );
const formControls = getFormControls( form );

console.log('formControls: ', formControls);

Całość: https://codepen.io/ChrissP92/pen/EvoMWM

1 odpowiedź

0 głosów
odpowiedź 17 sierpnia 2017 przez Jedras Maniak (54,860 p.)
Atrybut id dla danego elementu musi być unikalny w strukturze danej strony. Dublować możesz klasy. Tutaj zamiast id chyba powinno być "name" jak mniemam.

Podpinanie zdarzeń (zamiast onclick): https://developer.mozilla.org/pl/docs/Web/API/Element/addEventListener

Podobne pytania

0 głosów
1 odpowiedź 476 wizyt
pytanie zadane 29 września 2019 w JavaScript przez MAXIM7 Obywatel (1,990 p.)
0 głosów
0 odpowiedzi 238 wizyt
+1 głos
1 odpowiedź 265 wizyt
pytanie zadane 8 grudnia 2017 w JavaScript przez lastavenger Obywatel (1,060 p.)

92,574 zapytań

141,423 odpowiedzi

319,648 komentarzy

61,959 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...