Maybe everyone knows that js execution will block the parsing and rendering of the DOM tree, so will CSS loading block the parsing and rendering of the DOM tree? Next, let’s analyze it together. Principle Analysis So why does the above phenomenon occur? Let's analyze it from the browser's rendering process. Different browsers use different kernels, so their rendering processes are also different. There are currently two main WebKit rendering process Gecko rendering process From the two flowcharts above, we can see that the browser rendering process is as follows:
From the process we can see
DOMContentLoaded For browsers, there are two main events for page loading, one is DOMContentLoaded and the other is onLoad. There is nothing much to say about onLoad. It will only be triggered after all resources of the page are loaded. These resources include css, js, pictures, videos, etc. DOMContentLoaded, as the name implies, is triggered when the content of the page is parsed. Well, as we discussed above, css will block Dom rendering and js execution, and js will block Dom parsing. Then we can make the assumption that
Let's test the first case first: <!DOCTYPE html> <html lang="en"> <head> <title>css blocking</title> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <script> document.addEventListener('DOMContentLoaded', function() { console.log('DOMContentLoaded'); })  </script> <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet"> </head> <body> </body> </html> The experimental results are as follows: From the animated picture we can see that the DOMContentLoaded event has been triggered before the css is loaded. Because there is no js code behind the css. Next, we will test the second case. It is very simple. Just add a line of code after the css. <!DOCTYPE html> <html lang="en"> <head> <title>css blocking</title> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <script> document.addEventListener('DOMContentLoaded', function() { console.log('DOMContentLoaded'); }) </script> <link href="https://cdn.bootcss.com/bootstrap/4.0.0-alpha.6/css/bootstrap.css" rel="stylesheet"> <script> console.log('Is it my turn yet?'); </script> </head> <body> </body> </html> We can see that the DOMContentLoaded event is triggered only after the css loading is complete. Therefore, we can conclude that:
Summarize From the above, we can draw the following conclusions:
Therefore, in order to avoid users seeing a long white screen time, we should increase the CSS loading speed as much as possible, such as using the following methods:
This is the end of this article on whether CSS will block page rendering. For more information about CSS blocking page rendering, please search for previous articles on 123WORDPRESS.COM or continue to browse the related articles below. I hope you will support 123WORDPRESS.COM in the future! |
<<: My CSS framework - base.css (reset browser default style)
>>: Details of watch monitoring properties in Vue
Description and Introduction Docker inspect is a ...
Judgment symbols are often used in MySQL, and not...
Table of contents 1. First install echarts in the...
Common scenarios of MySQL: getting the intersecti...
I just finished installing MySQL 5.7.19 in the ea...
In life, the Internet is everywhere. We can play ...
In Beginners' Understanding MySQL Deadlock Pr...
Effect To implement HTML, first prepare a clean H...
Preface Currently, the front-end solves cross-dom...
Table of contents 1. Software and system image 2....
Preface If you are going to interview for a Linux...
Preface: For the implementation of digital additi...
This article example shares the specific code of ...
1 Overview System centos8, use httpd to build a l...
Table of contents Preface 1. Install Docker 2. In...