Diskuze: Prečo script ktorý funguje v <body> nefunguje ako subor.js?
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí JavaScript, jsme si ověřili nabyté zkušenosti z kurzu.
Nejsem si jist, ale mám za to, že ten skript se spustí hned, jak se načte, takže se ani nestihne načíst ten odstavec. Zkus to JS udělat takto:
window.onload = function() {
var answer1 = "It's alright";
var answer2 = "He is called 'Johnny'";
var answer3 = 'He is called "Johnny"';
document.getElementById("demo").innerHTML = answer1 + "<br>" + answer2 + "<br>" + answer3;
}
Nebo můžeš přidat atribut defer.
Je to způsobeno tím, že prohlížeč zpracovává dokument (-> vytváří DOM) postupně od shora dolu.
Nahoře narazí na tvůj JS (je úplně jedno, jestli je importován nebo vložen), ten načte a zpracuje jej.
Může se stát, že v okamžiku, kdy se skript zpracovává ještě není DOM vytvořený, nebo není kompletní, proto se nemusí najít žádný element s #demo a tedy se skript "neprovede".
Pokud umístíš JS na spodek stránky, všechno se provede tak, jak má, jelikož je již připraven DOM a skript se má na čem provést.
Dá se tomu samozřejmě zabránit, pokud spustíš skript až po načtení dokumentu, jak psal Jan Lupčík.
Velmi často jsou dotazy typu proč to na lokálu ("u mě v počítači") funguje a na serveru ne. To je dáno tím, že u tebe v počítači je přístup k souborům okamžitý, takže se okamžitě vytvoří DOM a skript najde chtěný element. Na serveru je však situace jiná. Musíš všechny soubory stahovat a pokud stáhneš skript dříve, než HTML, které se ještě musí převést na DOM, skript se prostě neprovede. Dá se tomu zabránit částečně různým cachováním atp., ale to není moc spolehlivé. Nejspolehlivější je použití .onload či umístění všech skriptů na spodek stránky, což doporučuji, protože nikdy nevíš, je skript, který importuješ má tento problém ošetřený.
Takto?
<script type="text/javascript" src="script.js" defer></script>
Nefunguje to.
<script src="script.js" type="text/javascript"></script>
Takhle ne?
Pýtal som sa Jirku Gracíka na umiestnenie atribútu defer.
Ano, takto. Tak pak to může být tím, že to prohlížeč nepodporuje nebo to funguje jinak, než si pamatuji
Zobrazeno 8 zpráv z 8.