-
Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed2.atman.pl!newsfeed.atman.pl!.P
OSTED!not-for-mail
From: Marek S <p...@s...com>
Newsgroups: pl.comp.www
Subject: Re: getElementById zwraca null
Date: Sun, 18 Nov 2018 18:56:09 +0100
Organization: ATMAN - ATM S.A.
Lines: 38
Message-ID: <pss93t$rda$1@node1.news.atman.pl>
References: <psa4kg$1d6er$1@portraits.wsisiz.edu.pl>
NNTP-Posting-Host: 89-70-94-204.dynamic.chello.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=utf-8; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: node1.news.atman.pl 1542563773 28074 89.70.94.204 (18 Nov 2018 17:56:13 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Sun, 18 Nov 2018 17:56:13 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101
Thunderbird/60.3.0
In-Reply-To: <psa4kg$1d6er$1@portraits.wsisiz.edu.pl>
Content-Language: pl
Xref: news-archive.icm.edu.pl pl.comp.www:403533
[ ukryj nagłówki ]W dniu 2018-11-11 o 21:49, Jivanmukta pisze:
> Pliki .html, .css, .js przechodzą pomyślnie walidację.
> Nie mam innego elementu o id='property_pictures' ani innego o
> id="main_title", literówki w id nie ma.
> DOM dokument jest załadowany w chwili wywołania.
> Nie usuwam elementów property_pictures ani main_title przy pomocy
> JavaScript.
> Przejrzałem w Google strony "getElementById returns null" i nie
> znalazłem przyczyny mojego błędu.
> Prosiłbym o podpowiedź co robię źle.
Taki błąd powstaje raczej tylko w przypadku gdy DOM nie jest w pełni
załadowany. Nic innego mi do głowy nie przychodzi. A kiedy może się tak
dziać? Z praktyki webdewelopera najczęściej to:
1. Jakiś skrypt zmienia / przebudowuje strukturę dokumentu. Również może
to być refresh.
2. Strona ładuje się i następuje chwilę potem przekierowanie do jej
samej (3xx). Sprawdź po stronie sieci w narzędziach czy nie ma czegoś
takiego.
Ustaw też w na początku funkcji animateMainTitle jakiś log do konsoli by
sprawdzić czy nie następuje podwójne wywołanie w samym JS.
3. Ponadto z nazwy w/w funkcji wnioskuję iż naruszasz strukturę DOM by
coś zanimować. Nie wiem jak konkretnie animujesz więc tylko zgaduję.
Jeśli np. używasz innerHTML gdzieś dalej do zapisu, to wtedy takie cuda
mogą się dziać. Nie należy używać do tego celu innerHTML bo jest
strasznie wolne gdyż wymusza odświeżanie _CAŁEJ_ struktury DOM. Wtedy
okresowo możesz tracić dostęp do DOM mimo iż pozornie wydaje Ci się, że
nic się w niej nie zmienia. To dość częsty błąd początkujących
programistów JS a i zaawansowani czasem też o tym nie wiedzą.
--
Pozdrawiam,
Marek
Następne wpisy z tego wątku
- 19.11.18 08:54 Jivanmukta
- 19.11.18 09:31 Jivanmukta
- 19.11.18 22:57 Marek S
- 17.12.18 15:04 Jivanmukta
Najnowsze wątki z tej grupy
- php, linki z nazwami a $_GET, SEO
- www polityka pl captcha
- dyktatura brudnego palucha
- www.znanylekarz.pl
- Czy pytanie o sczytywanie stron programami/skryptami to tu?
- Grupy webdevowe
- Jak wydrukować stronę?
- IIS, kilka witryn
- linki <a href="/strona.php"> (ze slashami)
- co rozszerza stronę??
- responsywny akapit <p>
- Czy istnieje jakiś emulator przeglądarek pod Mac'a?
- taka sama konfiguracja dla localhost i produkcji
- TypeScript - jak uzyskać zmienne prywatne? Gdzie korzyści z TS?
- Jak wywołać funkcję Javascript (ES6) z modułu?
Najnowsze wątki
- 2024-03-29 Gdańsk => DevOps Engineer (Kubernetes, AWS) <=
- 2024-03-29 Warszawa => AI Specialist <=
- 2024-03-29 Warszawa => Marketing Specialist (SaaS) <=
- 2024-03-29 Warszawa => Specjalista ds. Marketingu (SaaS) <=
- 2024-03-29 Warszawa => Android Developer <=
- 2024-03-29 Zielona Góra => Engineer R&D Energy Electronics <=
- 2024-03-29 Zielona Góra => Inżynier R&D Energoelektronik <=
- 2024-03-29 Warszawa => Inżynier oprogramowania .Net <=
- 2024-03-28 Amnesty International o izraelskim apartheidzie wobec Palestynczyków
- 2024-03-28 Warszawa => Senior Rust Software Engineer <=
- 2024-03-28 Przegląd po terminie
- 2024-03-28 Wrocław => Handlowiec w branży IT <=
- 2024-03-28 Warszawa => International freight forwarder <=
- 2024-03-28 Warszawa => Technical Tribe Leader (Java Background) <=
- 2024-03-28 Eltec nie zyje?