Il comportamento predefinito del browser quando incontra un elemento script è di interrompere il processo del documento (DOM), caricare il file dello script ed eseguirlo. Solo dopo l'esecuzione del codice dello script il browser riprende a processare il resto dell'HTML della pagina.
Per questo motivo non è possibile accedere agli elementi della pagina da uno script caricato nell'head della pagina (o comunque inserito prima degli elementi necessari). Le soluzioni comunemente adottate sono quelle di inserire gli script in coda alla pagina (appena prima della chiusura del tag body) oppure di specificare nello script stesso che il codice dovrà essere eseguito solo a seguito dell'evento load del body (jQuery mette a disposizione anche un evento ready - $(document).ready() - che viene scatenato prima che il documento sia effettivamente completo, non contemplando ad esempio il caricamento delle immagini).
Con HTML5 possiamo invece indicare direttamente al browser di posticipare l'esecuzione di uno script fino a che il documento non sarà completamente disponibile semplicemente specificando l'attributo defer:
<script src="sample.js" defer></script>
L'attributo defer è però valido solo per gli script che abbiano un attributo src specificato, ovvero solo se lo script è contenuto in un file esterno rispetto al documento.
L'attributo defer è supportato dalle ultime versioni di tutti i principali browser.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Persistere la ChatHistory di Semantic Kernel in ASP.NET Core Web API per GPT
Creare una libreria CSS universale: Immagini
Utilizzare il metodo IntersectBy per eseguire l'intersection di due liste
Il nuovo controllo Range di Blazor 9
Utilizzare DeepSeek R1 con Azure AI
Fissare una versione dell'agent nelle pipeline di Azure DevOps
Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
Ridurre il reflow cambiando il CSS
Gestione file Javascript in Blazor con .NET 9
Gestire codice JavaScript con code splitting e lazy loading
Supportare la crittografia di ASP.NET Core con Azure Container App
Inference di dati strutturati da testo con Semantic Kernel e ASP.NET Core Web API
I più letti di oggi
- Usare i settings di serializzazione/deserializzazione di System.Text.Json di ASP.NET all'interno di un'applicazione non web
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2025 - Milano