Maison  >  Article  >  interface Web  >  Explication détaillée indiquant si le chargement CSS entraînera le blocage_CSS tutoriel_CSS_Web production de pages

Explication détaillée indiquant si le chargement CSS entraînera le blocage_CSS tutoriel_CSS_Web production de pages

php中世界最好的语言
php中世界最好的语言original
2018-03-21 14:47:311082parcourir

Cette fois, je vais vous donner une explication détaillée pour savoir si le chargement de CSS provoquera un blocage. Quelles sont les précautions qui provoquent le blocage du chargement de CSS.

L'examen est enfin terminé. Aujourd'hui, je me suis soudain rappelé que alors que je cherchais un stage il y a quelque temps, l'intervieweur de Toutiao m'a demandé que l'exécution de js bloquerait l'analyse et le rendu du DOM. arborescence, donc le chargement CSS bloquera l'arborescence DOM. Donc, je ferai ensuite un test sur l'analyse et le rendu de l'arborescence DOM par chargement CSS.

Afin de terminer ce test, apprenons d'abord comment utiliser Chrome pour définir la vitesse de téléchargement

1 Ouvrez la console Chrome (appuyez sur F12), vous pouvez voir l'image ci-dessous, le focus est L'endroit où j'ai dessiné le cercle rouge

2. Cliquez sur l'endroit où j'ai dessiné le cercle rouge (Pas de limitation), vous verrez l'image ci-dessous, nous choisissons l'option GPRS

3. De cette façon, la limite supérieure de la vitesse de téléchargement de nos ressources sera limitée à 20kb/s. Bon, venons-en à notre. sujet principal

Le chargement CSS bloquera-t-il l'analyse et le rendu de l'arborescence DOM ?

Parlez en code :

<!DOCTYPE html>
<html lang="en">
  <head>
    <title>css阻塞</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
      h1 {
        color: red !important
      }
    </style>
    <script>
      function h () {
        console.log(document.querySelectorAll(&#39;h1&#39;))
      }
      setTimeout(h, 0)
    </script>
    <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet">
  </head>
  <body>
    <h1>这是红色的</h1>
  </body>
</html>

Hypothèse : le chargement CSS bloquera l'analyse de l'arborescence DOM et Rendu

Résultat de l'hypothèse : avant le chargement de bootstrap.css, le contenu suivant ne sera pas analysé ni rendu, donc ce que nous voyons au début devrait être un écran blanc et h1 ne sera pas affiché. Et le résultat de console.log devrait être un tableau vide pour le moment.

Résultat réel : comme indiqué ci-dessous

Le CSS bloquera-t-il l'analyse de l'arborescence DOM ?

Comme nous pouvons le voir sur l'image ci-dessus, lorsque le CSS n'a pas été chargé, h1 ne s'affiche pas, mais la sortie de la console est la suivante

On peut savoir que l'arborescence DOM a au moins été analysée en h1 à ce moment-là, mais le CSS n'a pas encore été chargé, ce qui signifie que le CSS ne bloquera pas l'analyse de l'arborescence DOM.

Le chargement CSS bloquera-t-il le rendu de l'arborescence DOM ?

D'après l'image ci-dessus, on peut également voir que lorsque le css n'a pas été chargé, la page affiche un écran blanc. Ce n'est que lorsque le css est chargé que la police rouge est. affiché, c'est-à-dire que bien que le contenu suivant ait été analysé, il n'a pas été rendu. Par conséquent, le chargement CSS bloquera le rendu de l’arborescence DOM.

Évaluation personnelle de ce mécanisme

En fait, je pense que cela peut aussi être un mécanisme d'optimisation du navigateur. Parce que lorsque vous chargez du CSS, vous pouvez modifier le style du nœud DOM suivant. Si le chargement du CSS ne bloque pas le rendu de l'arborescence DOM, alors une fois le CSS chargé, l'arborescence DOM devra peut-être être redessiné ou refondu, ce qui a causé des pertes inutiles. J'analyse donc simplement d'abord la structure de l'arborescence DOM, termine le travail qui peut être fait, puis attends que votre CSS soit chargé, puis restitue l'arborescence DOM selon le style final. Cette approche sera en effet meilleure en termes. de performances.

Le chargement de CSS bloquera-t-il l'exécution de js ?

De l'inférence ci-dessus, nous pouvons conclure que le chargement CSS ne bloquera pas l'analyse de l'arborescence DOM, mais il bloquera le rendu de l'arborescence DOM. Alors, le chargement CSS bloquera-t-il l'exécution de js ?

De même, vérifiez via le code.

<!DOCTYPE html>
<html lang="en">
  <head>
    <title>css阻塞</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <script>
      console.log(&#39;before css&#39;)
      var startDate = new Date()
    </script>
    <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet">
  </head>
  <body>
    <h1>这是红色的</h1>
    <script>
      var endDate = new Date()
      console.log(&#39;after css&#39;)
      console.log(&#39;经过了&#39; + (endDate -startDate) + &#39;ms&#39;)
    </script>
  </body>
</html>

Hypothèse : le chargement CSS sera bloquer l'exécution des js suivants

Résultat attendu : le code js derrière le lien ne doit pas être exécuté tant que le chargement du CSS n'est pas terminé

Résultat réel :

Nous pouvons voir sur l'image ci-dessus que le code js situé avant l'instruction de chargement CSS est exécuté en premier, mais le code situé après l'instruction de chargement CSS n'est exécuté que lorsque le chargement CSS est terminé. Cela montre également que le chargement CSS bloquera l'exécution des instructions js suivantes. Voir l'image ci-dessous pour les résultats détaillés (le chargement CSS a pris plus de 5600 ms) :

Conclusion

À partir de ce qui précède, nous pouvons Les conclusions suivantes sont tirées :

Le chargement 1.css ne bloquera pas l'analyse de l'arborescence DOM
Le chargement 2.css bloquera le rendu de l'arborescence DOM
Le chargement 3.css bloquera le exécution des instructions js suivantes

Par conséquent, afin d'éviter que les utilisateurs voient un long temps d'écran blanc, nous devons améliorer autant que possible la vitesse de chargement des CSS. Par exemple, nous pouvons utiliser les méthodes suivantes :

1. (car CDN, selon les conditions de votre réseau, sélectionnera le nœud le plus proche avec du contenu mis en cache pour vous fournir des ressources, réduisant ainsi le temps de chargement)
2. Compressez le CSS (vous pouvez utiliser de nombreux outils d'empaquetage, tels que webpack, gulp, etc., vous pouvez également activer la compression gzip)
3. Utilisez le cache de manière raisonnable (les paramètres de contrôle du cache, d'expiration et de balise électronique sont tous bons, mais une chose à laquelle il faut faire attention est qu'une fois le fichier mis à jour, vous devez éviter la mise en cache et l'apport. L'une des solutions et prévention consiste à ajouter un numéro de version après le nom du fichier)
4. Réduisez le nombre de requêtes http, fusionnez plusieurs fichiers CSS ou écrivez-le simplement directement dans un style en ligne (une lacune du style en ligne) Il ne peut tout simplement pas être mis en cache)

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur. le site php chinois !
Lecture recommandée :

Comment créer une ligne de 0,5 pixel en CSS

Implémentation de la barre de menu de transition en douceur de la transition CSS3

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:
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