Diskuze: TypeError: document.querySelector(...) is null
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 5 zpráv z 5.
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj,
chyba bude nejspíš způsobena tím, že document.querySelector('#show_modal') voláš ještě předtím, než nějaký '#show_modal' vůbec existuje. Tzn. tvůj JS kód bys měl volat buď po zmiňované HTML části nebo při události dokončení načtení stránky (např. DOMContentLoaded).
Ahoj, přesně v tom byla chyba. Ale jak jsem psal s JS se moc nekamarádím takže takováhle trivialita mi zabrala celkem dost času než jsem na tom přišel. Problém byl i v tom že u tohoto:
document.querySelector('#show_modal')
.addEventListener('click', toggleModal)
jsem před addEventListener zapoměl dát tečku, a víceméně to fungovalo, pak jsem si toho všiml a tečku dopsal. Pokud opomenu to že se modál otevřel a zavřel po kliknutí kamkoliv. Tak mě ani hned netrklo že bych nařed měl ty elementy deklarovat.
Pro lepší přehlednost je dobré to napsat na jeden řádek. Pak chybějící tečka bude jasně vidět.
document.querySelector('#show_modal').addEventListener('click', toggleModal)
Nejsem zastáncem rozdělení na řádky, jako máš ty, ale třeba ti to vyhovuje více. Nebál bych se i používat středíky, z kódu je pak jasné, kde přesně příkaz končí.
Mi ten kod funguje, ale musel jsem si ho doplnit. Takze, jestli to mas jinak,
tak je mozne, ze ho mas spatne
Doporucuji tagy script volat az pred koncem /body.
https://jsfiddle.net/jesbxwky/
<style>.modal_hidden{display:none;}</style>
<div class="content">
<button id="show_modal">Learn more</button>
</div>
<div class="modal modal_hidden">
<div class="modal_contents">
<div class="modal_close">
<span>X</span>
</div>
<p>This is modal content</p>
</div>
</div>
<script>
const toggleModal = () => {
document.querySelector('.modal')
.classList.toggle('modal_hidden');
}
document.querySelector('#show_modal')
.addEventListener('click', toggleModal)
document.querySelector('.modal_close')
.addEventListener('click', toggleModal)
</script>
Zobrazeno 5 zpráv z 5.