他的龙根本太大了_动漫美女被吸乳视频漫画_欧美xxxx性疯狂bbbb_天天看天天爽天天摸天天添

前端性能優(yōu)化指北-關(guān)于有些細(xì)節(jié)和思路

2021-3-31    前端達(dá)人

目錄

1. 比你最強(qiáng)的競(jìng)爭(zhēng)對(duì)手快20%

2. 反應(yīng)時(shí)間為100毫秒,幀數(shù)是每秒60幀

3. 首次有效渲染時(shí)間要低于1.25秒,速度指數(shù)要低于1000

定義你所需要的環(huán)境

4. 選擇和安裝你的開(kāi)發(fā)環(huán)境

5. 漸進(jìn)增強(qiáng)(progressive enhancement)

6. AMP還是Instant Articles?

7. 選擇適合你的CDN

開(kāi)始優(yōu)化

8. 直接確定優(yōu)化順序

9. 使用符合標(biāo)準(zhǔn)的技術(shù)

10. 考慮微優(yōu)化和漸進(jìn)啟動(dòng)

12. HTTP的緩存頭使用的合理嗎?

13. 減少使用第三方庫(kù),加載JavaScript異步操作

14. 圖片是否被正確優(yōu)化?

15. 圖片的進(jìn)一步優(yōu)化

15.1 如何使用webpack將靜態(tài)素材快速托管到ImageX,并開(kāi)啟http/2

16. 網(wǎng)頁(yè)字體優(yōu)化了嗎?

17. 快速執(zhí)行關(guān)鍵部分的CSS

18. 通過(guò)tree-shaking和code-splitting減少凈負(fù)載

19. 提升渲染性能

20. 預(yù)熱網(wǎng)絡(luò)連接,加快傳輸速度

HTTP/2

21. 準(zhǔn)備好使用HTTP/2

22. 適當(dāng)部署HTTP/2

23. 確保服務(wù)器安全可靠

快速入門(mén)

 

微優(yōu)化是保持性能最好的辦法,但是又不能有太過(guò)明確的優(yōu)化目標(biāo),因?yàn)檫^(guò)于明確的目標(biāo)會(huì)影響在項(xiàng)目中做的每一個(gè)決定。以下是一些不同的模型,請(qǐng)按照自己舒服的順序閱讀

1. 比你最強(qiáng)的競(jìng)爭(zhēng)對(duì)手快20%

根據(jù)一個(gè)心理學(xué)研究,你的網(wǎng)站最少在速度上比別人快20%,才能讓用戶感覺(jué)到你的網(wǎng)站比別人的更快。這個(gè)速度說(shuō)的不是整個(gè)頁(yè)面的加載時(shí)間,而是開(kāi)始加載渲染的時(shí)間,首次有效渲染時(shí)間(例如頁(yè)面需要加載主要內(nèi)容的時(shí)間),或者交互時(shí)間(指的是頁(yè)面或者應(yīng)用中主要的頁(yè)面加載完成,并主備好與用戶進(jìn)行交互的時(shí)間)。

在Moto G(一個(gè)中端三星設(shè)備)和Nexus 4(比較主流的設(shè)備)上衡量開(kāi)始渲染時(shí)間(用WebPagetest)以及首頁(yè)有效渲染時(shí)間(用Lighthouse),最好是在一個(gè)開(kāi)放的實(shí)驗(yàn)室中,使用規(guī)范的3G,4G和Wi-Fi鏈接。

 

你可以通過(guò)你的分析報(bào)告看看你的用戶處在哪個(gè)階段,選取其中前90%的用戶體驗(yàn)來(lái)做測(cè)試。接著收集數(shù)據(jù),建一個(gè)表格,篩去20%的數(shù)據(jù)并預(yù)設(shè)一個(gè)目標(biāo)(如:性能預(yù)算)。現(xiàn)在你可以將上述兩個(gè)值進(jìn)行對(duì)比檢測(cè)。如果你始終維持著你的目標(biāo)并且通過(guò)一點(diǎn)一點(diǎn)改變腳本去加快交互時(shí)間,那么上述方法就是合理可行的。

 

如果前端工程師們都在積極的參與項(xiàng)目概念,UX以及視覺(jué)設(shè)計(jì)的決定,這將會(huì)給整個(gè)項(xiàng)目帶來(lái)巨大收益。地圖設(shè)計(jì)的決定違背了性能理念,所以他在這份清單內(nèi)的順序有待考慮。

2. 反應(yīng)時(shí)間為100毫秒,幀數(shù)是每秒60幀

RAIL性能模型會(huì)為你提供一個(gè)優(yōu)秀的目標(biāo),既盡最大的努力在用戶初始操作后的100毫秒內(nèi)提供反饋。為了達(dá)到這個(gè)目標(biāo),頁(yè)面需要放棄權(quán)限,并將權(quán)限在50毫秒內(nèi)交回給主線程。對(duì)于像動(dòng)畫(huà)一樣的高壓點(diǎn),最好的方法就是什么都不做,因?yàn)槟阌肋h(yuǎn)無(wú)法達(dá)到最小絕對(duì)值。
同理,動(dòng)畫(huà)的每一幀都需要在16毫秒內(nèi)完成,這樣才能保證每秒60幀(一秒/60=16.6毫秒),如果可以的話最好能在10毫秒內(nèi)完成。因?yàn)闉g覽器需要一定的時(shí)間去在屏幕上渲染新的幀,而且你的代碼需要在16.6毫秒內(nèi)完成執(zhí)行。要注意,上述目標(biāo)應(yīng)用于衡量項(xiàng)目的運(yùn)行性能,而非加載性能。

3. 首次有效渲染時(shí)間要低于1.25秒,速度指數(shù)要低于1000

縱使這個(gè)目標(biāo)實(shí)現(xiàn)起來(lái)非常困難,你的最終目標(biāo)也應(yīng)該是讓開(kāi)始渲染時(shí)間低于1秒且速度指數(shù)低于1000(在網(wǎng)速快的地方)。對(duì)于首次有效渲染時(shí)間,上限最好是1250毫秒。對(duì)于移動(dòng)端,3G下移動(dòng)設(shè)備首次渲染時(shí)間低于3秒都是可以接受的。稍微高一點(diǎn)也沒(méi)關(guān)系,但千萬(wàn)別高太多。

定義你所需要的環(huán)境

4. 選擇和安裝你的開(kāi)發(fā)環(huán)境

不要過(guò)多的關(guān)注當(dāng)下最流行的工具,堅(jiān)持選擇適合自己開(kāi)發(fā)環(huán)境的工具,例如Grunt、Gulp、Webpack、PostCSS,或者組合起來(lái)的工具。只要這個(gè)工具運(yùn)行的速度夠快,而且沒(méi)有給你的維護(hù)帶來(lái)太大問(wèn)題,這就夠了。

5. 漸進(jìn)增強(qiáng)(progressive enhancement)

在構(gòu)建前端結(jié)構(gòu)的時(shí)候,應(yīng)始終將漸進(jìn)增強(qiáng)作為你的指導(dǎo)原則。首先設(shè)計(jì)并且構(gòu)建核心體驗(yàn),隨后再完善那些為高性能瀏覽器設(shè)計(jì)的高級(jí)特性的相關(guān)體驗(yàn),創(chuàng)建彈性體驗(yàn)。如果你的網(wǎng)頁(yè)可以在使用低速網(wǎng)絡(luò)、老舊顯示器的很慢的電腦上運(yùn)行飛快,那么在光纖高配電腦上它只會(huì)運(yùn)行的更快。

6. AMP還是Instant Articles?

根據(jù)你整體組織結(jié)構(gòu)的優(yōu)先順序和策略,你可以考慮使用Google的AMP或Facebook的Instant Articles。要知道沒(méi)有這些你也可以達(dá)到不錯(cuò)的性能,但是AMP可以提供一個(gè)性能不錯(cuò)的免費(fèi)的內(nèi)容分發(fā)網(wǎng)絡(luò)框架(CDN),Instant Articles可以在Facebook上促進(jìn)你的性能。你也可以建立progressive web AMP

7. 選擇適合你的CDN

根據(jù)你的動(dòng)態(tài)數(shù)據(jù)量,可以將一部分內(nèi)容外包給靜態(tài)網(wǎng)站生成工具,將它置于CDN上,從中生成一個(gè)靜態(tài)版本,從而避免那些數(shù)據(jù)庫(kù)的請(qǐng)求。也可以選擇基于CDN的靜態(tài)主機(jī)平臺(tái),通過(guò)交互組件豐富你的頁(yè)面(JAMStack)。注意CDN是否可以很好的處理(或分流)動(dòng)態(tài)內(nèi)容。沒(méi)必要單純的將你的CDN限制為靜態(tài)。反復(fù)檢查CDN是否執(zhí)行了內(nèi)容的壓縮和轉(zhuǎn)化,檢查智能HTTP/2傳輸和緩存服務(wù)器(ESI),注意哪些靜態(tài)或動(dòng)態(tài)的部分處在CDN的邊緣(最接近用戶的服務(wù)器)。

開(kāi)始優(yōu)化

8. 直接確定優(yōu)化順序

首先應(yīng)該弄清楚你想解決的問(wèn)題是什么。檢查一遍你所有的文件(JavaScript,圖片,字體,第三方script文件以及頁(yè)面中重要的模塊,例如輪播,復(fù)雜信息圖標(biāo)和多媒體內(nèi)容),并將他們分類(lèi)。
列一個(gè)表格。明確瀏覽器上應(yīng)該有的基礎(chǔ)核心內(nèi)容,哪些部分屬于為高性能瀏覽器設(shè)計(jì)的升級(jí)體驗(yàn),哪些是附加內(nèi)容(那些不必要或者可以被延時(shí)加載的部分,例如字體,不必要的樣式,輪播組件,播放器,社交網(wǎng)站入口,很大的圖片)。

9. 使用符合標(biāo)準(zhǔn)的技術(shù)

使用符合標(biāo)準(zhǔn)的技術(shù)向過(guò)時(shí)的瀏覽器提供核心體驗(yàn),向老式瀏覽器提供增強(qiáng)體驗(yàn), 同時(shí)對(duì)所加載的內(nèi)容要有嚴(yán)格的把控。即首要加載核心體驗(yàn)部分,將增強(qiáng)部分放在DomContentLoaded,把額外內(nèi)容發(fā)在load事件中。以前我們可以通過(guò)瀏覽器的版本推斷出設(shè)備的性能,但現(xiàn)在我們已經(jīng)無(wú)法推測(cè)了。因?yàn)楝F(xiàn)在市場(chǎng)上很多廉價(jià)的安卓手機(jī)都不考慮內(nèi)存限制和CPU性能,直接使用高版本的Chrome瀏覽器。一定要注意,在我們沒(méi)有其他選擇的時(shí)候,我們選擇的技術(shù)同時(shí)可能成為我們的限制。

10. 考慮微優(yōu)化和漸進(jìn)啟動(dòng)

在一些應(yīng)用中,可以在渲染頁(yè)面前先初始化應(yīng)用。最好先顯示框架,而不是一個(gè)進(jìn)度條或指示器。使用可以加速初始渲染時(shí)間的模塊或技術(shù)(例如tree-shakingcode-splitting),因?yàn)榇蟛糠中阅軉?wèn)題來(lái)自于應(yīng)用引導(dǎo)程序的初始分析時(shí)間。還可以在服務(wù)器上提前編譯,從而減輕部分客戶端的渲染過(guò)程,從而快速輸出結(jié)果。最后,考慮使用Optimize.js來(lái)加快初始加載速度,它的原理是包裝優(yōu)先級(jí)高的調(diào)用函數(shù)(雖然現(xiàn)在已經(jīng)沒(méi)什么必要了)。

 

到底采用客戶端渲染還是服務(wù)器端渲染?不論哪種做法,我們的目標(biāo)都是建立漸進(jìn)啟動(dòng):使用服務(wù)器端渲染可以得到很短的首次有效渲染時(shí)間,這個(gè)渲染過(guò)程也包括小部分的JavaScript文件,目的是使交互時(shí)間盡可能的接近首次有效渲染時(shí)間。接下來(lái),盡可能的增加一些應(yīng)用的非必要功能。不幸的是,正如Paul Lewis所說(shuō),框架基本上對(duì)開(kāi)發(fā)者是沒(méi)有優(yōu)先級(jí)的概念的,因此漸進(jìn)啟動(dòng)在很多庫(kù)和框架上是很難實(shí)施的。如果你有時(shí)間的話,還是考慮使用策略去優(yōu)化你的性能吧。

12. HTTP的緩存頭使用的合理嗎?

仔細(xì)檢查一下例如expires,cache-control,max-age以及其他HTTP緩存頭是否被正確的使用。一般來(lái)說(shuō),資源不論在短時(shí)間(如果它會(huì)被頻繁改動(dòng))還是不確定的時(shí)間內(nèi)(如果它是靜態(tài)的)都是可緩存的——你大可在需要的時(shí)候在URL中成改版本。如果可能,使用為指紋靜態(tài)資源設(shè)計(jì)的Cache-control:immutable,從而避免二次驗(yàn)證(2016年12月,只有FireFox在https://處理中支持)。你可以使用,Heroku的primer on HTTP caching headers,Jake Archibald的 ”Caching Best Practices”,還有IIya Grigorik的HTTP caching primer作為指導(dǎo)。

13. 減少使用第三方庫(kù),加載JavaScript異步操作

當(dāng)用戶請(qǐng)求頁(yè)面時(shí),瀏覽器會(huì)抓取HTML同時(shí)生成DOM,然后抓取CSS并建立CSS對(duì)象模型,最后通過(guò)匹配DOM和CSS對(duì)象生成渲染樹(shù)。在需要處理的JavaScript文件被解決之前,瀏覽器不會(huì)開(kāi)始對(duì)頁(yè)面進(jìn)行渲染。作為開(kāi)發(fā)者,我們要明確的告訴瀏覽器不要等待,直接開(kāi)始渲染。具體方法是使用HTML中的deferasync兩個(gè)屬性。事實(shí)上,defer更好一些(因?yàn)閷?duì)于IE9及以下用戶對(duì)于IE9及以下用戶,很有可能會(huì)中斷腳本)。同時(shí),減少第三方庫(kù)和腳本的使用,尤其是社交網(wǎng)站的分享按鍵和<iframe>嵌入(比如地圖)。你可以使用靜態(tài)的社交網(wǎng)站分享按鍵(例如SSBG的)和指向交互地圖的靜態(tài)鏈接去代替他們。

14. 圖片是否被正確優(yōu)化?

盡可能的使用帶有srcset,sizes還有<picture>元素的響應(yīng)式圖片。你也可以利用<picture>元素的AVIF、WEBP格式,用JPEG格式作為替補(bǔ)(參見(jiàn)Andreas Bovens的code snippet)或是使用內(nèi)容協(xié)商(使用接受頭)。本身可以使用自己的PS或者skecth嘗試導(dǎo)出,若不能導(dǎo)出,可以嘗試 火山引擎的ImageX圖像處理服務(wù)(不知道怎么使用可以自行百度搜索 "火山引擎 ImageX")可以支持多種格式輸出,比如AVIF、webp格式;

我曾經(jīng)寫(xiě)過(guò)這篇文檔可以對(duì)照一下:高效率圖像壓縮處理服務(wù), 參考截圖:

 

你也可以使用客戶端提示,現(xiàn)在瀏覽器也可以做到。在用來(lái)生成響應(yīng)圖片的源文件過(guò)少時(shí),使用響應(yīng)圖片斷點(diǎn)生成器。

15. 圖片的進(jìn)一步優(yōu)化

當(dāng)你在編寫(xiě)登錄界面的時(shí)候,發(fā)現(xiàn)頁(yè)面上的圖片加載的特別快,這時(shí)你需要確認(rèn)一下圖片進(jìn)一步優(yōu)化的思路只要有三點(diǎn):

  • 降低圖片的分辨率,如果瀏覽器中展示區(qū)域100*100,此時(shí)展示 400*400 就屬于資源浪費(fèi),這也是顯著提高圖片響應(yīng)速度最直接的方法;
  • 降低圖片壓縮的質(zhì)量,圖片壓縮質(zhì)量,使用有損壓縮,比如圖片壓縮質(zhì)量90 和75對(duì)人眼可見(jiàn)的范圍內(nèi)都可以接受,常見(jiàn)支持有損壓縮的圖片格式比如,jpeg、wepb、heic、avif等圖片格式支持圖片有損壓縮;
  • 改變圖像壓縮的壓縮方式,改變圖片的壓縮算法也能更高效的提高圖片優(yōu)化圖片提高速度,比如 常見(jiàn)圖像壓縮率(圖像畫(huà)質(zhì)等同前提下): HEIF (heic) > AVIF (avif、avis) >webP(awebp) > jpeg > png 等;

正常情況下PNG是原圖格式,體積特別大,巧的是業(yè)界對(duì)PNG 有pngquant 使用Median Cut量化算法的修改版本和其他技術(shù)來(lái)緩解Median Cut的不足,可以最大效率保留信息的前提下降低png 的體積大??;如果我們把如上的一些優(yōu)化處理起來(lái),我使用的過(guò)程中發(fā)現(xiàn),火山引擎的imagex 已經(jīng)完美的支持了上面三者的使用方法:下面我舉個(gè)例子做一下說(shuō)明:

http://imagex.75live.com/tos-cn-i-n9b2vwdhz3/public/attachments/2021/03/11/GyVrojIWFkQOKSAzYnUmlQxvaESnPaZYxgpu9v1Z.png~tplv-n9b2vwdhz3-12:300:200.webp 這個(gè)是 png的原圖處理好的結(jié)果,在這個(gè)url中imagex 給出了一種url語(yǔ)義,"~tplv--模板名稱(chēng):[模板參數(shù)].圖像格式"  通過(guò)改變300:300 能改改變壓縮率,通過(guò)參數(shù)能夠調(diào)整壓縮質(zhì)量,通過(guò)改變webp-->avif 可以轉(zhuǎn)換成不同的壓縮方法;

更巧妙的是在這,就算指定輸出png后仍然還可以設(shè)置質(zhì)量參數(shù)

 

如果你還覺(jué)得不夠,那你可以通過(guò)多重背景圖片技術(shù)來(lái)提高圖片的感知性能。

15.1 如何使用webpack將靜態(tài)素材快速托管到ImageX,并開(kāi)啟http/2

這里發(fā)現(xiàn)一個(gè)第三方寫(xiě)的但被官方推薦的開(kāi)源插件https://github.com/Cmaxd/veimagex-webpack-loader ,通過(guò)配置webpack-loader 插件的方式可以將圖片上傳到ImageX,然后將圖片使用不同的圖片模板訪問(wèn)就可以滿足需求,同一個(gè)圖片可以使用多個(gè)地址,例如avif、webp、jpeg 使用 <picture> 標(biāo)簽進(jìn)行降級(jí) 或者判斷瀏覽器支持降級(jí);

 

16. 網(wǎng)頁(yè)字體優(yōu)化了嗎?

你用來(lái)修飾網(wǎng)頁(yè)字體的服務(wù)很有可能毫無(wú)用處,包括字形和額外的特性。如果你在使用開(kāi)源的字體,嘗試用字體庫(kù)中某一個(gè)小的子集或是自己歸類(lèi)一個(gè)小的子集從而壓縮文件大?。ɡ缤ㄟ^(guò)一些特殊的注音符號(hào)引用Latin)。WOFF2 support是個(gè)非常不錯(cuò)的選擇,如果瀏覽器不支持,那你可以將WOFF和OTF作為備用。你也可以從Zach Leatherman的“Comprehensive Guide to Font-Loading Strategies”一文中選擇一個(gè)合適的策略,然后使用服務(wù)器來(lái)緩存字體。如果想要快速入門(mén),Pixel Ambacht的教程與案例會(huì)讓你的字體變得盡然有序。如果你用的是第三方服務(wù)器主機(jī),沒(méi)辦法自己在服務(wù)器上對(duì)字體進(jìn)行操作,一定看看Web Font Loader

17. 快速執(zhí)行關(guān)鍵部分的CSS

為了確保瀏覽器盡可能快的渲染你的頁(yè)面,先收集頁(yè)面首次可見(jiàn)部分的CSS文件(也叫決定性CSS或上半版CSS)進(jìn)行渲染,然后將它加入頁(yè)面的<head>部分,從而避免重復(fù)操作。因?yàn)槁龁?dòng)階段對(duì)交換包大小的限制,你關(guān)鍵CSS文件的大小也被限制在14KB左右。如果高于這個(gè)值,瀏覽器需要重復(fù)一些步驟來(lái)獲取更多的樣式。關(guān)鍵CSS是允許你這樣做的??赡軐?duì)每個(gè)模板都需要這個(gè)操作。如果可能,考慮一下用Fiament Group用的條件內(nèi)斂方法。

通過(guò)HTTP/2,關(guān)鍵CSS可以單獨(dú)存為CSS文件,通過(guò)服務(wù)器傳輸,而且可以避免HTML膨脹。服務(wù)器傳輸缺乏連續(xù)支持,并且存在一些超高速緩存的問(wèn)題(Hooman Beheshti演示的前144頁(yè))。事實(shí)上,這樣會(huì)導(dǎo)致網(wǎng)絡(luò)緩沖區(qū)膨脹。因?yàn)門(mén)CP的慢啟動(dòng),服務(wù)器傳輸在穩(wěn)定的連接下會(huì)更有效率。所以你可能需要建立帶有緩存的HTTP/2服務(wù)器傳輸機(jī)制。但請(qǐng)記住,新的cache-digest規(guī)則會(huì)否定手動(dòng)建立的需要緩存的服務(wù)器的請(qǐng)求。

18. 通過(guò)tree-shaking和code-splitting減少凈負(fù)載

Tree-shaking是通過(guò)保留那些在項(xiàng)目過(guò)程中真正需要的代碼從而清理你的構(gòu)建過(guò)程的一種方式。你可以用Webpack 2來(lái)提出那些沒(méi)用的住配置文件,用UnCSSHelium從CSS中取出不需要的樣式。同理,也可以考慮學(xué)習(xí)一下如何編寫(xiě)高效的CSS選擇器,以及如何避免膨脹和高費(fèi)的樣式

Code-splitting是另一個(gè)Webpack特性,它可以根據(jù)按需加載的塊將你的代碼分開(kāi)。只要你在代碼中定義了分離點(diǎn),Webpack便會(huì)處理好相關(guān)的輸出文件。它基本上能保證你初始下載的內(nèi)容很小,而且在需求被添加時(shí)按需請(qǐng)求代碼。

Rollup所展示的結(jié)果要比Browserify配置文件所顯示的好得多。所以當(dāng)我們想使用類(lèi)似工具的時(shí)候,或許應(yīng)該看看Rollupify,它將ECMAScript2015模塊變成了一個(gè)更大的CommonJS模塊——因?yàn)樾∧K沒(méi)準(zhǔn)有出乎意料的高性能成本,這源自于你對(duì)打包工具模塊系統(tǒng)的選擇。

19. 提升渲染性能

使用類(lèi)似CSS containment的方法對(duì)高消耗組建進(jìn)行隔離,從而限制瀏覽器樣式的范圍,可以作用在為無(wú)canvas的瀏覽工作的布局和裝飾工作中,或是用在第三方工具上。要確保頁(yè)面滾動(dòng)和出現(xiàn)動(dòng)畫(huà)效果時(shí)沒(méi)有延遲,別忘了之前提到過(guò)的每秒60幀的原則。如果沒(méi)辦法做到,那就盡可能保證每秒幀數(shù)的大致范圍在15到60幀。使用CSS中的will-change通知瀏覽器哪些元素和屬性發(fā)生了變化。也記得要衡量渲染執(zhí)行中的性能(可以用DevTools)。可以參照Udacity上Paul Lewis的免費(fèi)課程——瀏覽器渲染優(yōu)化,作為入門(mén)。還有一篇Sergey Chikuyonok的文章講了如何正確的用GPU動(dòng)畫(huà)

20. 預(yù)熱網(wǎng)絡(luò)連接,加快傳輸速度

使用頁(yè)面框架,對(duì)高消耗組建延遲加載(字體,JS文件,循環(huán)播放,視頻和內(nèi)嵌框架)。使用資源提示來(lái)節(jié)省在dns-prefetch(指的是在后臺(tái)執(zhí)行DNS檢索),preconnect(指要求瀏覽器在后臺(tái)進(jìn)行握手鏈接(DNS,TCP,TLS)),prerender(指要求瀏覽器在后臺(tái)對(duì)特定頁(yè)面進(jìn)行渲染),preload(指的是提前取出暫不執(zhí)行的源文件)。根據(jù)你瀏覽器的支持情況,盡量使用preconnect來(lái)代替dns-prefetch,而且在使用prefetchprerender要特別小心——后者(prerender)只有在你非常確信用戶下一步操作的情況下再去使用(比如購(gòu)買(mǎi)流程中)。

HTTP/2

21. 準(zhǔn)備好使用HTTP/2

Google開(kāi)始向著更安全網(wǎng)頁(yè)的方向努力,并且將所有Chrome上的HTTP網(wǎng)頁(yè)定義為“不安全”時(shí),你或許應(yīng)該考慮是繼續(xù)使用HTTP/1.1,還是將目光轉(zhuǎn)向HTTP/2環(huán)境。雖然初期投入比較大,但是使用HTTP/是大趨勢(shì),而且在熟練掌握之后,你可以使用service worker和服務(wù)器推送技術(shù)讓行性能再提升一大截。
現(xiàn)在,Google計(jì)劃把所有HTTP頁(yè)面標(biāo)記為不安全,并且將HTTP安全指示器設(shè)置為與Chrome用來(lái)攔截HTTPS的紅色三角相同的圖標(biāo)。

使用HTTP/2的環(huán)境的缺點(diǎn)在于你要轉(zhuǎn)移到HTTPS上,并且根據(jù)你HTTP/1.1用戶的數(shù)量(主要指使用過(guò)時(shí)操作系統(tǒng)和過(guò)時(shí)瀏覽器的用戶),你需要適應(yīng)不同的建構(gòu)過(guò)程,才能發(fā)送不同的建構(gòu)。注意:不論是遷移還是新的構(gòu)建過(guò)程都可能非常棘手而且耗時(shí)很多。

 

22. 適當(dāng)部署HTTP/2

重申,使用HTTP/2協(xié)議之前,你需要徹底排查目前為止你所使用協(xié)議的情況。你需要在打包組建和同時(shí)加載很多小組間之間找到平衡。

一方面,你可能想要避免將很多資源鏈?zhǔn)芥溄樱c其將你全部的界面分割成許多小模塊,不如將他們壓縮使之成為建構(gòu)過(guò)程的一部分,之后給它們賦予可檢索的信息并加載它們。這樣的話,對(duì)一文件將不再需要重新下載整個(gè)樣式清單或JavaScript文件。

另一方面,封裝是很有必要的,因?yàn)橐淮蜗驗(yàn)g覽器發(fā)送太多JavaScript文件會(huì)出問(wèn)題。首先,壓縮會(huì)造成損壞。得益于dictionary reuse,壓縮大文件不會(huì)對(duì)文件造成損害,壓縮小文件則不然。確實(shí)有方法可以解決這個(gè)問(wèn)題,但這不是本文討論的范疇。其次,瀏覽器還沒(méi)有優(yōu)化到可以對(duì)類(lèi)似工作流進(jìn)行優(yōu)化。例如,Chrome會(huì)引發(fā)進(jìn)程間通信(IPCs),這些通信的數(shù)量與資源的數(shù)量成正比,而這成百上千個(gè)資源將會(huì)消耗大量的瀏覽器的執(zhí)行時(shí)間。
Chrome的Jake Archibald建議,為了用HTTP/2達(dá)到最好的效果,考慮一下逐步加載CSS文件

當(dāng)然你可以考慮逐步加載CSS文件。很顯然,你這樣做對(duì)HTTP/1.1的用戶非常不利,所以你可能需要根據(jù)不同的瀏覽器建立多個(gè)版本來(lái)應(yīng)對(duì)你的調(diào)度過(guò)程,這樣就會(huì)使過(guò)程略微復(fù)雜。你也可以避免HTTP/2連接的合并,同時(shí)受益于HTTP/2來(lái)使用域名碎片,但是實(shí)現(xiàn)起來(lái)有些困難。

我們到底應(yīng)該做什么呢?如果你粗略的用過(guò)HTTP/2,似乎成功的發(fā)送過(guò)10個(gè)左右的包(在老是瀏覽器上運(yùn)行的也不錯(cuò))。那你就能著手開(kāi)始試驗(yàn)并且為你的網(wǎng)站找到平衡點(diǎn)。

23. 確保服務(wù)器安全可靠

所有的瀏覽器都支持HTTP/2并且使用TLS,這是有你可能想要避免安全警告,并刪除頁(yè)面上沒(méi)用的元素。好好檢查你的安全頭部是否設(shè)置正確排除已知的缺陷檢查證書(shū)。

如果還沒(méi)有遷移到HTTP, 你那可以先看看HTTPS準(zhǔn)則(The HTTPS-Only Standard)。確保所有外部插件和監(jiān)視腳本都能被HTTPS正確加載,確保沒(méi)有跨站腳本出現(xiàn),HTTP腳本傳輸?shù)陌踩^內(nèi)容安全頭也都設(shè)置正確。

快速入門(mén)

這份清單綜合性很強(qiáng),幾乎介紹了所有的可用的優(yōu)化方式。那么,如果你只有一個(gè)小時(shí)進(jìn)行優(yōu)化,你應(yīng)該干什么呢?讓我們從中總結(jié)10個(gè)最有用的來(lái)。別忘了在你開(kāi)始優(yōu)化前和結(jié)束優(yōu)化后,記錄你的結(jié)果,包括開(kāi)始渲染時(shí)間以及在3G,有限連接下的速度。

但沒(méi)關(guān)系,本文只是一個(gè)普通大綱(希望能做到綜合性強(qiáng)),你應(yīng)該根據(jù)自己的工作環(huán)境列一份適合自己的清單。最重要的,在開(kāi)始優(yōu)化之前,先對(duì)項(xiàng)目中存在的問(wèn)題有一個(gè)明確的了解。


轉(zhuǎn)自:csdn論壇 ,

藍(lán)藍(lán)設(shè)計(jì)m.ssll180.com )是一家專(zhuān)注而深入的界面設(shè)計(jì)公司,為期望卓越的國(guó)內(nèi)外企業(yè)提供卓越的UI界面設(shè)計(jì)、BS界面設(shè)計(jì) 、 cs界面設(shè)計(jì) 、 ipad界面設(shè)計(jì) 、 包裝設(shè)計(jì) 、 圖標(biāo)定制 、 用戶體驗(yàn) 、交互設(shè)計(jì)、 網(wǎng)站建設(shè) 、平面設(shè)計(jì)服務(wù)

日歷

鏈接

個(gè)人資料

存檔