What happens from entering the URL to rendering the page?
Enter the URL and press Enter:
1) The browser will look for the IP address of the URL in the browser cache; If not, go to the system cache, or if not, go to the router cache; If there is no host file, go to the DNS server
2) Then DNS gives an IP to the browser; Based on this IP address, the browser encapsulates the request information, request description and request parameters into a TCP packet, which is transmitted from the transport layer, to the network layer, to the data link layer, to the physical layer, to the server, which parses the TCP packet and returns the corresponding page file.
3) The browser generates a DOM tree from an HTML file, a CSSOM tree from a CSS file, and then merges the two trees to generate a render tree, which then renders the page and displays it. It is important to note that when the browser parses the HTML file, it will suspend the generation of the DOM tree if it encounters inline or outbound JS code. After the JS code is executed, it can continue to generate and render the tree.
In terms of page rendering and network request response performance optimization, we can do the following optimization:
2. CDN concurrency, resource compression, reduce the number of requests 3. There will be an article written after preloading or lazy loading.
Browser rendering process:
Segmentfault.com/a/119000000…
HTML: Generates a DOM Tree
1. The browser obtains the original Html bytes from the server resources or local disk resources through the network and converts them into corresponding characters according to the specified encoding format
2. The browser converts characters to various exact tags specified by the W3C HTML5 standard, such as “”, “”
3. Build a Dom tree
CSS Parsing :CSS Object Model (CSSOM)
The CSS parsing process is similar to HTML parsing, which is performed by the browser using its own parser. Generally, the parsing process is top-down. CSS files are parsed into StyleSheet objects, and each object contains CSS rules. CSS rule objects contain selection and declaration objects, as well as other objects that correspond to the CSS syntax. After the CSS is resolved, a CSS Rule Tree with the following structure is generated.
Render:
Build render tree = “Layout =” draw
① Build the render tree
Earlier, we built the DOM tree and the CSSOM tree from the input HTML and CSS, but the two are separate objects: the DOM describes the content of the document, and the CSSOM describes the style rules applied to the document. The browser combines the DOM and CSSOM to build a Render tree that captures all the visible DOM content on the page and the CSSOM style applied to each node. The process is as follows:
1 Start at the root of the DOM tree and traverse every visible node. Some nodes are not visible (such as script tags, meta tags, etc.) because they do not show up in the rendering result, so they are ignored
Some nodes hidden by CSS are also ignored in the rendering tree, such as node 2 with the display: None rule applied. Match and apply the corresponding CSSOM rules for each visible node. 3. Generate visible nodes with content and calculation styles
We built a DOM tree and a CSSOM tree from the input HTML and CSS, but the two are separate objects: the DOM describes the content of the document, and the CSSOM describes the style rules applied to the document. The browser combines the DOM and CSSOM to build a Render tree that captures all the visible DOM content on the page and the CSSOM style applied to each node. The process is as follows:
1. Start at the root of the DOM tree and traverse every visible node
- Some nodes are not visible (such as script tags, meta tags, etc.) and are ignored because they do not show up in the rendering results
- Some nodes hidden by CSS are also ignored in the rendering tree, such as nodes with the display: None rule applied
2. Match and apply CSSOM rules for each visible node
(3) are generatedcontentandCalculate the styleVisible node of
So far, we’ve figured out which nodes are visible and how they should be evaluated, but we haven’t figured out their exact position and size in the device viewport — that’s what we do in the Layout phase, also known as reflow.
There are two concepts involved: redraw and refluxing
Check out blog.csdn.net/qq_41807645… This article looks at it in detail. The article details how to avoid backflow and improve performance
Repaint: When some of the attributes of an element change, such as the font color, background color, etc., but the size does not change, this process is called repaint.
Reflow: Because browser rendering is a top-down process, when a change is found to affect the layout, you need to go back and re-render. This process is called reflow. Reflow is almost inevitable, and common effects such as tree directories collapsing and expanding (essentially showing and hiding elements) will cause reflow in the browser. Mouse slide, click… As long as these actions cause changes in the space area, positioning, margins and other attributes of some elements on the page, they will cause it to be re-rendered in, around, and even the entire page. Basically, reflow can be caused by several reasons:
1. Initialize the web page. 2. Add and delete elements when JS operates DOM tree. 3. Change the size of some elements. 4. Changes to CSS propertiesCopy the code
(3) draw
In the paint phase, the system traverses the render tree and calls the renderer’s “paint” method to display the content on the screen. Similarly, similar to the layout process, there are two types: global and incremental
This is how the browser renders
About the <Script> tag
JS can modify the content of a page, style, and respond to user interactions. JS introduces many new dependencies between DOM, CSSOM, and JS execution, resulting in significant delays in the browser processing and rendering of the page:
- When the browser encounters the
- JavaScript execution is paused until CSSOM is ready
Here are the important conclusions:
-
CSS does not block DOM parsing, but it does block DOM rendering.
-
JS blocks DOM parsing, but the browser “peeks” at the DOM and preloads related resources.
-
Page rendering is triggered when the browser encounters a <script> tag without defer or async attributes, so if the CSS resource has not finished loading before the browser waits for it to finish loading before executing the script.
Reference link: juejin.cn/post/684490… (CSS and JS block DOM parsing and rendering in this way)