轉自:http://www.oschina.net/translate/loading-css-without-blocking-rendercss 本文展現了一種技術,它能經過異步下載樣式表,以阻止它們的下載阻塞頁面的渲染,從而儘量快的讓訪問者獲取到信息內容。html 警告! 我發這篇帖子全是好意,可是它並不負責讓讀它的人意識到下面將會遇到的問題. 社區很快地給了我許多的反饋 (有些反饋我很感激) ,而愈來愈明顯的是這項技術並不如我所但願的那樣穩定. 不像我那樣的成功地對它進行了測試和利用,許多開發者在 IE 和 Firefox 中都遇到了問題( F F測試版中直接崩潰) 而其餘人則報告在 Chrome 和 Safari 中是成功的。我如今的建議是: 不要將其用於產品。我計劃處理好這些反饋,並結合任何有關的信息對本文進行更新。git |
LeoXu 翻譯於 3天前0人頂github 頂 翻譯的不錯哦! web |
其它翻譯版本(1) |
這些技術背後的原理不是新的。例如燈絲(Filament)技術組已經發布了大量有關 加載CSS 和字體的內容. 我寫就本文以記錄我對加載非阻塞資源的想法和觀點。瀏覽器 觸發異步樣式下載的訣竅是使用一個 <link> 元素,並 爲media 屬性設置一個不可用的值 (我用的是 media="none", 不過其它的任何值也是能夠的)。當一個媒體查詢的結果值計算出來是 false 的時候,瀏覽器仍然會下載樣式表,可是不會在渲染頁面以前等待樣式表的資源可用。緩存
樣式表一下載好,media 屬性就必須被設置一個可用的值,以便樣式規則能被應用到 html 文檔中onload 事件就能夠用來將 media 屬性切換到all:服務器
|
LeoXu 翻譯於 3天前0人頂網絡 頂 翻譯的不錯哦! app |
這種加載 CSS 的方法將比標準的方法在向訪問者傳送有用信息的速度上快不少。相當重要的 CSS 加載時仍然能夠用通常的阻塞方式處理 (或者你也能夠爲了最終的性能對它進行內聯處理) ,而不重要的樣式則能夠慢慢下載,並在解析/渲染過程的後面一點的階段進行應用. 這一技術使用了 JavaScript,可是你也能夠在一個<noscript>元素中封裝一個等價的阻塞方式的 <link> 元素來處理不能運行 JavaScript 的瀏覽器:
這項技術有一個反作用。當一個非阻塞的樣式表完成加載,文檔就將進行重繪,以反映它定義的任何新的樣式規則。而注入新的樣式到頁面中會觸發內容迴流, 但這也只是在這對第一次沒有歷史緩存的頁面加載過程當中會是一個問題。因爲任何跟性能有關的東西,你都將要在須要控制一次迴流耗費超過潛在的速度優點時,進行必要的調整。 |
LeoXu 翻譯於 3天前0人頂 頂 翻譯的不錯哦! |
使用非阻塞 CSS 加載字體字體第一次繪製的性能是一個問題,它們是阻塞式的資源,也會讓應用它們的文本在該字體下載時不可見 。使用上述示例中的非阻塞連接,就可能在幕後下載包含字體數據的樣式表,不阻塞壓面的渲染:
font.css 包含一個 base64 編碼的 WOFF 版本的 Merriweather 字體。
main.css 包含了須要應用到站點的全部樣式規則。下面是字體的聲明:
當字體正在下載時,第一個匹配到的備用回退字體 (這裏就是 Lucida Grande) 被用來渲染頁面的內容。 一旦字體樣式表被應用了,Merriweather 就會被使用. 我嘗試去確保回退的字體將類似的佈局特徵共享給優先選擇的字體,那樣不可避免的迴流就儘量微妙了。 |
LeoXu 翻譯於 3天前0人頂 頂 翻譯的不錯哦! |
我在基於一個模擬的 3G 網絡鏈接的 Chrome 中,使用個人 Google Analytics Debugger 站點 拿阻塞和非阻塞方式進行了對比測試。本地的測試產生了以下所示的網絡圖;注意 DOMContentLoaded 在更早的 450ms 觸發了,而資源在運用了非阻塞技術後下載起來更快了: 模擬 3G 網絡的圖形。頂部顯示了阻塞式的字體。底部顯示了非阻塞式的字體。 將其部署到一個測試服務器並在 3G 鏈接環境下運行 webpagetest 構造產生了以下時間線 : 3G 時間線。頂部顯示阻塞式的字體,底部展現非阻塞式的字體。 |
LeoXu 翻譯於 3天前0人頂 頂 翻譯的不錯哦! |
兩種方法都花了2.8秒鐘來完整的渲染頁面,可是非阻塞方法比通常的阻塞方法使得繪製早了1秒鐘。在在主樣式表進行了內聯的狀況下運行相同的測試,顯示了在將非阻塞 CSS 被應用於處理字體時有0.7秒的時間優點: 主 CSS 內容的 3G 時間線。頂部顯示阻塞式字體,底部顯示非阻塞式字體。 這一技術對於字體的效果確實很好,可是我也建議對新的 CSS 字體加載模塊保持密切關注,它會給與咱們超過字體加載的更多的控制能力。 |
LeoXu 翻譯於 3天前0人頂 頂 翻譯的不錯哦! |
總結加載字體是應用非阻塞技術的一個例子,而他也能夠被用於其它的目的,好比從核心的 CSS 處分離出 JavaScript 加強的樣式。 我已經開始去嘗試將樣式分紅框架(核心佈局) 和展示 (其它全部的東西)這種想法,它可讓重要的頁面佈局阻塞頁面渲染,而可見的樣式數據延遲一會。 |
LeoXu 翻譯於 3天前0人頂 頂 翻譯的不錯哦! |