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
Potenziare la ricerca su Cosmos DB con Full Text Search
Gestire i dati con Azure Cosmos DB Data Explorer
Collegare applicazioni server e client con .NET Aspire
Supportare la sessione affinity di Azure App Service con Application Gateway
Gestire progetti .NET + React in .NET Aspire
Creare una libreria CSS universale: Nav menu
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Applicare un filtro per recuperare alcune issue di GitHub
Gestire codice JavaScript con code splitting e lazy loading
Utilizzare una qualunque lista per i parametri di tipo params in C#
Triggerare una pipeline su un altro repository di Azure DevOps
I più letti di oggi
- ASPItalia.com Future Web Conference: 15 gennaio 2008, L'Aquila
- Download della RC1 di Windows.NET
- Gestione CSS in Blazor con .NET 9
- Gestione file Javascript in Blazor con .NET 9
- Documentare i servizi REST con Swagger e OpenAPI con .NET 9
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!