摘要:屏幕的變化就被稱為或者是。而瀏覽器的目標之一就是減少以及的負面影響,其中的一個策略就是干脆不做,又或者說至少不是現(xiàn)在做。但有時腳本語句會破化瀏覽器優(yōu)化,并使其刷新隊列以及執(zhí)行所有批處理的改變。
**首先說翻譯這篇文章的目的其實是,之前回答的關于瀏覽器js渲染的問題被打臉了 ?_? ,
不得不正視自己半路出家學前端的事實,所以這篇文章就算是自己的一個筆記吧,學而時習之,不亦樂乎,翻譯錯了,還請批評指正**
原文鏈接:Rendering: repaint, reflow/relayout, restyle
正文:
今天我們來談談這個從page2.0(譯者注:page2.0不怎么常見,應該是作者自創(chuàng)的,介紹鏈接在文章結尾)生命周期的詞:渲染,有時候它甚至發(fā)生在瀑布流當中。
那么,瀏覽器是如何靠著一大塊html,css,javascript代碼在屏幕上顯示你的頁面的呢?
不同的瀏覽器有不同的實現(xiàn)方式,但是下邊的圖會展示一個當代碼被下載到電腦里之后所有瀏覽器的共同實現(xiàn)(或多或少都有)
瀏覽器把我們的html源代碼解析并且初始化成一個dom樹,dom樹是一個數據結構,它的特點包括,每個html標簽都在這個樹上有一個對應的節(jié)點,當然標簽當中的文本塊也在dom樹上有一個相應的文本節(jié)點,這個dom樹的根節(jié)點就是documentElement(也就是標簽)
瀏覽器解析css代碼,針對一些像-webkit、-moz以及一些不認識的寫法做忽略,css的優(yōu)先級是這樣的:最基本的瀏覽器默認樣式,然后就是來自外部引入的用戶腳本,最高級的是在頁面里邊寫在