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

JavaScript -> document.querySelector nie działa z backtickami i zmiennymi

VPS Starter Arubacloud
0 głosów
337 wizyt
pytanie zadane 23 września 2021 w JavaScript przez Doge Gaduła (3,320 p.)

Witam, otrzymuję error:

Uncaught TypeError: Cannot read properties of null (reading 'style')

w moim fragmenie kodu:

for(let j=1; j<=player_count; j++)
        {
            for(let i=1; i<=39; i++)
            {
                if(document.querySelector(`.player-${j}-owned-cards .owned-card${i}`))
                {
                    //document.querySelector(`.player-${j}-owned-cards .owned-card${i}`).style.visibility = 'hidden';
                }
            }
            for(let i=5; i<=35; i+=10)
            {
                document.querySelector(`.player-${j}-owned-cards .owned-card${i}`).style.fontSize = '0.3rem';
            }
        }

gdzie w instrukcji if przechodzi test, ale w

for(let i=5; i<=35; i+=10)
            {
                document.querySelector(`.player-${j}-owned-cards .owned-card${i}`).style.fontSize = '0.3rem';
            }

dostaję wyżej wymieniony błąd, a querySelector jest identyczny, .style.fontSize jest poprawną metodą, a wartość '0.3rem' również jest prawidłowa, w debugerze Chrome na elemencie zostaje nadany font-size: 0.3rem; ale dostaję taki error. Kiedy dałem konkretną wartość zamiast zmiennej, to nie było errora. Dlaczego tak się dzieje?

1
komentarz 23 września 2021 przez ScriptyChris Mędrzec (190,190 p.)

Wykonsoluj sobie zmienne i oraz j przed kodem, który rzuca błąd i sprawdź czy wartości są prawidłowe.

komentarz 23 września 2021 przez Doge Gaduła (3,320 p.)

Zapomniałem, że te wszystkie pętle są w jeszcze innej pętli, kiedy nie było 2 razy iteratora "i", to już nie wyrzuca errora:

for(let j=1; j<=39; j++)
            {
                if(document.querySelector(`.player-${i}-owned-cards .owned-card${j}`))
                {
                    //document.querySelector(`.player-${j}-owned-cards .owned-card${i}`).style.visibility = 'hidden';
                }
            }
            for(let k=5; k<=35; k+=10)
            {
                console.log(i, k);
                document.querySelector(`.player-${i}-owned-cards .owned-card${k}`).style.fontSize = '0.2rem';
            }

tylko jest nadal problem - font-size i tak nie jest zmieniany w tych elementach, a konsola wyrzuca prawidłowe liczby. O co może chodzić?

1
komentarz 23 września 2021 przez ScriptyChris Mędrzec (190,190 p.)
Czy możesz podlinkować minimalny kod pozwalający na reprodukcję tego problemu np. na stronie codepen.io?
komentarz 23 września 2021 przez Doge Gaduła (3,320 p.)
edycja 23 września 2021 przez Doge
Jasne, mogę podać nawet cały kod:

https://codepen.io/DogeDoge/pen/BaZOdRe

Miejsce błędu jest zakomentowane w 147. linii. Powinna się zmniejszać czcionka na szarych kartach po bokach planszy
1
komentarz 23 września 2021 przez ScriptyChris Mędrzec (190,190 p.)

Wygodniej by to było sprawdzać na minimalnym kodzie niż całym. :P

Błąd pojawia się, bo w danym momencie w DOM nie ma elementu o selektorze '.player-2-owned-cards .owned-card5'. jest natomiast '.player-owned-cards .player-1-owned-cards'.

komentarz 24 września 2021 przez Doge Gaduła (3,320 p.)
Do naprawy musiałem pozmieniać nazwy iteratorów w pętlach for, a w naprawionym kodzie bez errora nie zmieniał się font-size mimo tego, że był w debugerze Chrome podany, ponieważ na childach w css był również podany font-size i po prostu ten z parenta nie wpływał na nic.

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
1 odpowiedź 129 wizyt
0 głosów
1 odpowiedź 209 wizyt
pytanie zadane 19 października 2017 w JavaScript przez lastavenger Obywatel (1,060 p.)
0 głosów
2 odpowiedzi 306 wizyt
pytanie zadane 24 września 2020 w JavaScript przez Kubs Mądrala (5,190 p.)

92,451 zapytań

141,261 odpowiedzi

319,073 komentarzy

61,853 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...