Cette fois, je vous apporte une explication détaillée du chargement asynchrone de JavaScript, et quelles sont les précautions lors du chargement asynchrone de JavaScript. Voici des cas pratiques, prenons un. regarder.
Le problème du chargement synchrone
Le js par défaut est chargé de manière synchrone. Le "chargement" ici peut être compris comme une analyse et une exécution, plutôt que comme un "téléchargement". , le navigateur charge les ressources demandées par le code dans un style cascade au lieu de les bloquer, mais l'exécution de js est toujours bloquée. Quels problèmes cela pose-t-il ? Si ma page d'index a besoin de charger du js, mais qu'une des requêtes n'obtient pas de réponse pendant une longue période, elle bloque l'exécution du code js suivant (chargement synchrone) et le rendu de la page ne peut pas continuer (si l'introduction du js est dans la tête après l'étiquette).
<script type="text/javascript" src='http://china-addthis.googlecode.com/svn/trunk/addthis.js'></script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
this is a test
Copier après la connexion
Par exemple, le code ci-dessus est enregistré sous forme de fichier index.html. Le corps principal de la page est une simple chaîne, mais une fois le code exécuté, la page. reste vide. Pourquoi ? Étant donné que le js demandé ne peut pas être chargé pendant une longue période (peut-être en raison du blocage de Google, etc.), l'exécution du code suivant est bloquée et la page ne peut pas être restituée. Peut-être suggérerez-vous que si vous mettez le code js avant
, la page sera rendue en premier ! Bonne méthode, on essaye de mettre des js derrière :
this is a test
<script type="text/javascript" src='http://china-addthis.googlecode.com/svn/trunk/addthis.js'></script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
Copier après la connexion
La page est rendue instantanément, "ceci est un test" apparaît aussi rapidement au premier plan, le monde semble calme, mais :
this is a test
<script type="text/javascript" src='http://china-addthis.googlecode.com/svn/trunk/addthis.js'></script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
Copier après la connexion
J'ai simplement ajouté un morceau de code basé sur le code précédent, mais "hello world" n'a pas pu être affiché sur la console pendant longtemps. Évidemment, la requête js précédente a bloqué le chargement du code suivant. On s'est soudain rendu compte que changer la position de chargement de js nécessite seulement que cela puisse changer le rendu de la page, mais cela ne sert à rien au chargement de js, et js bloquera toujours.
Implémentation du chargement asynchrone js
Notre exigence semble très simple. Il peut afficher une chaîne dans la console pendant le chargement de la page. Pour le dire plus simplement, il s'agit de demander la première. Tout en segmentant les js fournis par Google, continuez à exécuter les js suivants, qui visent à réaliser un chargement asynchrone de js.
L'approche la plus courante consiste à générer dynamiquement des balises de script :
<body>
this is a test
<script type="text/javascript">
~function() {
var s = document.createElement('script');
s.src = 'http://china-addthis.googlecode.com/svn/trunk/addthis.js';
document.body.appendChild(s);
}();
</script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
<script type="text/javascript">
console.log('hello world');
</script>
</body>
Copier après la connexion
Mais il y a toujours un problème. Cette méthode de chargement empêchera le déclenchement de l'événement onload avant la fin du chargement, et de nombreuses pages maintenant Le code effectuera également un travail de rendu supplémentaire lors du chargement, il bloquera donc toujours le traitement d'initialisation de certaines pages :
<body>
this is a test
<script type="text/javascript">
~function() {
// function async_load() {
var s = document.createElement('script');
s.src = 'http://china-addthis.googlecode.com/svn/trunk/addthis.js';
document.body.appendChild(s);
// }
// window.addEventListener('load', async_load, false);
}();
window.onload = function() {
var txt = document.createTextNode(' hello world');
document.body.appendChild(txt);
};
</script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
</body>
Copier après la connexion
Par exemple, le code ci-dessus ne peut pas bien restituer "hello world", nous supprimons simplement les commentaires et laissons les js fournis par Google commencer à se charger de manière asynchrone pendant le chargement. Cela résout le problème du blocage du déclenchement de l’événement onload.
Ajout des événements DOMContentLoaded et OnLoad DOMContentLoaded : La page (document) a été analysée et les éléments dom de la page sont disponibles. Cependant, les images et sous-cadres référencés dans la page n'ont peut-être pas encore été chargés. OnLoad : Toutes les ressources de la page sont chargées (y compris les images). La progression du chargement du navigateur s'arrête à ce stade. Ces deux moments divisent la chronologie de chargement de la page en trois étapes.
Ce qui précède semble être une meilleure solution à ce problème, mais html5 fournit une méthode plus simple, l'attribut async !
this is a test
<script type="text/javascript" src='http://china-addthis.googlecode.com/svn/trunk/addthis.js' async='async'></script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
<script type="text/javascript">
console.log('hello world');
</script>
Copier après la connexion
async est un nouvel attribut de HTML5. L'attribut async précise qu'une fois le script disponible, il sera exécuté de manière asynchrone (il sera exécuté immédiatement une fois téléchargé).
Il convient de noter que l'attribut async ne s'applique qu'aux scripts externes (uniquement lors de l'utilisation de l'attribut src)
L'attribut defer est souvent mentionné avec async :
this is a test
<script type="text/javascript" src='http://china-addthis.googlecode.com/svn/trunk/addthis.js' defer='defer'></script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js'></script>
<script type="text/javascript">
console.log('hello world');
</script>
Copier après la connexion
semble être mis en œuvre L'effet est similaire, mais est-ce vraiment le même ? Jetons un coup d'œil à la définition de l'attribut defer.
Dans le passé, defer ne prenait en charge que les hacks IE, mais maintenant l'émergence de HTML5 a commencé à prendre pleinement en charge le report. L'attribut defer spécifie que le script ne sera exécuté qu'une fois le chargement de la page terminé. L'attribut defer s'applique uniquement aux scripts externes (uniquement lors de l'utilisation de l'attribut src). ps : Le report pris en charge par ie ne semble pas être le cas, car je n'ai aucun intérêt pour ie et je n'y approfondirai pas. Si vous êtes intéressé, vous pouvez vérifier les informations pertinentes.
Puisque async et defer apparaissent souvent ensemble, analysons-les !
S'il n'y a pas d'attributs async et defer (attribués à true, le même ci-dessous), le navigateur exécutera immédiatement le script js actuel et bloquera les scripts suivants s'il y a un attribut async, le processus de chargement et ; le rendu des éléments suivants du document sera effectué en parallèle avec le chargement et l'exécution du js actuel (de manière asynchrone) ; s'il existe un attribut defer, alors le processus de chargement des éléments suivants du document sera effectué en parallèle avec le chargement du script. js (de manière asynchrone), mais l'exécution de script.js sera effectuée dans tous les éléments (DOM), l'analyse est terminée, mais avant le déclenchement de l'événement DOMContentLoaded.
this is a test
<script type="text/javascript" src='http://china-addthis.googlecode.com/svn/trunk/addthis.js' defer='defer'></script>
<script type="text/javascript" src='http://libs.baidu.com/jquery/2.0.0/jquery.min.js' defer='defer'></script>
<script type="text/javascript" src='index.js' defer='defer'></script>
console.log('hello world');
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Le système d'exploitation Windows est l'un des systèmes d'exploitation les plus populaires au monde et sa nouvelle version Win11 a beaucoup attiré l'attention. Dans le système Win11, l'obtention des droits d'administrateur est une opération importante. Les droits d'administrateur permettent aux utilisateurs d'effectuer davantage d'opérations et de paramètres sur le système. Cet article présentera en détail comment obtenir les autorisations d'administrateur dans le système Win11 et comment gérer efficacement les autorisations. Dans le système Win11, les droits d'administrateur sont divisés en deux types : administrateur local et administrateur de domaine. Un administrateur local dispose de tous les droits d'administration sur l'ordinateur local
La technologie de détection et de reconnaissance des visages est déjà une technologie relativement mature et largement utilisée. Actuellement, le langage d'application Internet le plus utilisé est JS. La mise en œuvre de la détection et de la reconnaissance faciale sur le front-end Web présente des avantages et des inconvénients par rapport à la reconnaissance faciale back-end. Les avantages incluent la réduction de l'interaction réseau et de la reconnaissance en temps réel, ce qui réduit considérablement le temps d'attente des utilisateurs et améliore l'expérience utilisateur. Les inconvénients sont les suivants : il est limité par la taille du modèle et la précision est également limitée ; Comment utiliser js pour implémenter la détection de visage sur le web ? Afin de mettre en œuvre la reconnaissance faciale sur le Web, vous devez être familier avec les langages et technologies de programmation associés, tels que JavaScript, HTML, CSS, WebRTC, etc. Dans le même temps, vous devez également maîtriser les technologies pertinentes de vision par ordinateur et d’intelligence artificielle. Il convient de noter qu'en raison de la conception du côté Web
Explication détaillée de l'opération de division dans OracleSQL Dans OracleSQL, l'opération de division est une opération mathématique courante et importante, utilisée pour calculer le résultat de la division de deux nombres. La division est souvent utilisée dans les requêtes de bases de données. Comprendre le fonctionnement de la division et son utilisation dans OracleSQL est donc l'une des compétences essentielles des développeurs de bases de données. Cet article discutera en détail des connaissances pertinentes sur les opérations de division dans OracleSQL et fournira des exemples de code spécifiques pour référence aux lecteurs. 1. Opération de division dans OracleSQL
L'opérateur modulo (%) en PHP est utilisé pour obtenir le reste de la division de deux nombres. Dans cet article, nous discuterons en détail du rôle et de l'utilisation de l'opérateur modulo et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Le rôle de l'opérateur modulo En mathématiques, lorsqu'on divise un entier par un autre entier, on obtient un quotient et un reste. Par exemple, lorsque l’on divise 10 par 3, le quotient est 3 et le reste est 1. L'opérateur modulo est utilisé pour obtenir ce reste. 2. Utilisation de l'opérateur modulo En PHP, utilisez le symbole % pour représenter le module
Explication détaillée de la fonction d'appel système Linux system() L'appel système est une partie très importante du système d'exploitation Linux. Il fournit un moyen d'interagir avec le noyau système. Parmi elles, la fonction system() est l’une des fonctions d’appel système couramment utilisées. Cet article présentera en détail l’utilisation de la fonction system() et fournira des exemples de code correspondants. Concepts de base des appels système Les appels système sont un moyen permettant aux programmes utilisateur d'interagir avec le noyau du système d'exploitation. Les programmes utilisateur demandent au système d'exploitation en appelant des fonctions d'appel système
Explication détaillée de la commande curl de Linux Résumé : curl est un puissant outil de ligne de commande utilisé pour la communication de données avec le serveur. Cet article présentera l'utilisation de base de la commande curl et fournira des exemples de code réels pour aider les lecteurs à mieux comprendre et appliquer la commande. 1. Qu’est-ce que la boucle ? curl est un outil de ligne de commande utilisé pour envoyer et recevoir diverses requêtes réseau. Il prend en charge plusieurs protocoles, tels que HTTP, FTP, TELNET, etc., et fournit des fonctions riches, telles que le téléchargement de fichiers, le téléchargement de fichiers, la transmission de données, le proxy.
La relation entre js et vue : 1. JS comme pierre angulaire du développement Web ; 2. L'essor de Vue.js en tant que framework front-end ; 3. La relation complémentaire entre JS et Vue ; Vue.
Une explication détaillée de Promise.resolve() nécessite des exemples de code spécifiques. Promise est un mécanisme en JavaScript pour gérer les opérations asynchrones. Dans le développement réel, il est souvent nécessaire de traiter certaines tâches asynchrones qui doivent être exécutées dans l'ordre, et la méthode Promise.resolve() est utilisée pour renvoyer un objet Promise qui a été rempli. Promise.resolve() est une méthode statique de la classe Promise, qui accepte un