摘要:最少化請求用戶在瀏覽網(wǎng)頁時,超過的時間都是在請求下載網(wǎng)頁資源,包括圖片,樣式,腳本,等等,減少這些資源的下載請求數(shù)目,便成了讓網(wǎng)頁提速的關(guān)鍵。但需要提的是,中對請求的長度限制在字節(jié)以內(nèi)參考,所以如果超過這個長度,只能使用請求。
前端工程師常常被提起網(wǎng)站性能,如何讓網(wǎng)站訪問更快等問題,本文就做個總結(jié)。
最少化HTTP請求用戶在瀏覽網(wǎng)頁時,超過80%的時間都是在請求下載網(wǎng)頁資源,包括圖片,樣式,腳本,F(xiàn)lash等等,減少這些資源的下載請求數(shù)目,便成了讓網(wǎng)頁提速的關(guān)鍵。
當(dāng)然,如果頁面很簡單,資源少,網(wǎng)頁請求自然就少,如果網(wǎng)頁內(nèi)容很多,我們?nèi)绾巫龅綔p少資源請求數(shù)呢?這里有幾個方法:
合并靜態(tài)文件,將所有腳本、樣式文件合并到一個文件里,可以大大減少HTTP請求數(shù)。但如果每個頁面的靜態(tài)文件都不一樣,所有文件都合并到一起也會帶來麻煩,所以需要在開發(fā)過程中均衡處理合并。
CSS雪碧圖(Sprites),將CSS中用到的背景圖片合并到一張圖片上,然后通過background-position去定位想用到的圖片塊,可以減少圖片請求數(shù)。
使用data: URL scheme將圖片數(shù)據(jù)寫入到HTML或CSS文件中,雖然增加了HTML或CSS文件大小,但必要時,還是需要這么做來減少HTTP請求數(shù)。
將CSS文件放在頭部當(dāng)頁面內(nèi)容很多時,我們希望邊加載邊正確的顯示給用戶,你可能想把CSS文件放到頁面底部,這樣就可以優(yōu)先展示用戶內(nèi)容,但這會引起一個嚴(yán)重的問題,用戶先看到的是一個沒有樣式的頁面,之后閃一下(頁面重繪)又重新定義了樣式,這其實很影響用戶體驗。而最好的做法就是遵循HTML規(guī)范,把CSS文件放到文檔的HEAD標(biāo)簽里。
將JS文件放在底部JS腳本所引起的問題是阻塞了瀏覽器的并行下載,HTTP/1.1規(guī)范指出:每個域名下的資源的并行下載數(shù)量不得超過兩個,當(dāng)瀏覽器在下載JS文件時,不會進行其他下載,即使資源被分發(fā)在不同的域名。
避免CSS表達式如果要動態(tài)設(shè)置CSS屬性,CSS表達式(CSS expressions)就顯得尤其強(wei)大(xian),它在IE5.0中開始被支持,但又在IE8.0中被廢棄。比如以下樣式,背景色會在每個小時都被定義一次。
background-color: expression( (new Date()).getHours()%2 ? "#B8D4FF" : "#F08A00" );
可以看粗,expression方法接受一個Js語句去設(shè)置CSS屬性值,它只能被IE識別,所以在跨瀏覽器開發(fā)時(兼容IE),它就有了用武之地。
但是它的問題在于它執(zhí)行的非常頻繁,網(wǎng)頁渲染時執(zhí)行,窗口改變時執(zhí)行,甚至頁面滾動時、用戶移動鼠標(biāo)時它都會執(zhí)行!
減少CSS表達式執(zhí)行次數(shù)的方法是:當(dāng)頁面渲染完成后就給CSS屬性設(shè)定一個明確的值,或者在Js中監(jiān)聽網(wǎng)頁事件,事件觸發(fā)時再去設(shè)置CSS屬性值。如果一定要使用CSS表達式,請記住,它很可能會被執(zhí)行成千上萬次。
外鏈CSS和JS文件之所以外鏈CSS和JS文件會使頁面更快,是因為它們可以被瀏覽器緩存,否則每次請求HTML文檔時都會重復(fù)下載CSS和JS代碼,雖然內(nèi)聯(lián)CSS和JS可以減少HTTP請求數(shù),但是使得HTML文檔更大。
如果頁面比較簡單,JS和CSS都很少,使用內(nèi)聯(lián)代碼減少HTTP請求,反而會讓頁面更快。
壓縮靜態(tài)文件市面上的壓縮工具有很多,比如JSmin, YUI Compressor,GCC,pngcrush等等,可以根據(jù)業(yè)務(wù)需要選擇工具去壓縮靜態(tài)文件。
Ajax中優(yōu)先選擇GET請求使用XMLHttpRequest對象進行POST請求時,我們發(fā)現(xiàn),它其實是分為兩步完成,現(xiàn)發(fā)送請求頭信息,再發(fā)送請求數(shù)據(jù),所以最好使用GET請求,只需要發(fā)送一個TCP數(shù)據(jù)包(除非有很多Cookie數(shù)據(jù)),而且GET請求的數(shù)據(jù)可以被緩存。但需要提的是,IE中對GET請求的URL長度限制在2K字節(jié)以內(nèi)(參考support.microsoft.com),所以如果URL超過這個長度,只能使用POST請求。
延遲加載開發(fā)過程中,想想這個元素或腳本是不是頁面初始化所必須的,如果不是,就可以考慮延遲加載它們,比如默認被折疊的元素、需要用戶觸發(fā)才需要顯示的元素以及首屏之后的頁面元素等等。
預(yù)加載預(yù)加載看上去和上條矛盾,其實不然。當(dāng)瀏覽器處于空閑時,我們可以預(yù)先加載之后會使用到的頁面的元素(比如:圖片,JS,CSS),之后頁面再使用這些元素時會優(yōu)先從緩存中讀取。預(yù)加載分為這兩種形式:
無條件預(yù)加載(Unconditional):頁面一旦加載完成就去下載額外的元素,而這個元素并不一定在這個頁面上被使用,比如Google首頁加載了一張背景圖,這是為了搜索結(jié)果頁所準(zhǔn)備的。
條件預(yù)加載(Conditional):這是基于用戶行為做出下一步猜測而去加載元素,比如當(dāng)你輸入文字時會根據(jù)文字去下載不同元素。
減少DOM數(shù)如果一個頁面太復(fù)雜,意味著下載時間更長,同時JS訪問DOM的速度也會變慢。減少DOM數(shù)并不意味著需要移除內(nèi)容,而是我們可以使用更合理的HTML標(biāo)簽。還在使用Table布局?頁面一堆DIV標(biāo)簽,也許我們有更好更語義化的布局方法。
想知道頁面的DOM數(shù)量很簡單,只需要一行JS語句:
document.getElementsByTagName("*").length多域名分發(fā)內(nèi)容
使用多域名分發(fā)內(nèi)容可以可以增加瀏覽器并行下載數(shù),由于DNS解析也要耗時,一般2-4個域名比較合適。比如你可以把HTML或JSP,PHP等文檔文件放在www.example.org這個域名上,而把靜態(tài)文件放在static1.example.or或者static2.example.org上。
減少iframe的使用iframe可以讓HTML文檔嵌套在另一個HTML文檔內(nèi),想要更好的使用它們就必須知道它們的工作原理。
iframe優(yōu)點:
* 延遲加載廣告等第三方內(nèi)容
* 提供安全沙箱
* 并行下載腳本
iframe缺點:
* 代價昂貴
* 阻止父級頁面的加載
* 非語義化
Cookie常常被用在身份驗證或者存儲個人信息,他會通過HTTP頭信息在服務(wù)端和瀏覽器之間傳輸,為了減少HTTP響應(yīng)時間,我們有必要減小Cookie。通常有以下幾個方法:
清除不必要的Cookie
盡量減小Cookie內(nèi)容的長度
在適當(dāng)?shù)挠蛑性O(shè)置Cookie,保證其他子域不受影響
設(shè)定合適的Cookie的過期時間
更多關(guān)于Cookie的信息可以參考 When the Cookie Crumbles
減少DOM操作頻繁用JS操作DOM的開銷很大,我們可以通過以下幾種方式減少這種開銷:
1. 緩存獲取到的DOM元素
2. 批量處理元素,一次性更新到文檔
3. 盡量避免用JS改變頁面布局
當(dāng)過多的元素被綁定頻繁被觸發(fā)的事件,頁面響應(yīng)會變慢,這時我們就需要采用事件委托。如果你不需要等待所有圖片下載完成,可以使用DOMContentLoaded事件來代替onload事件。
使用link而不是@import引入CSS之前提到過,要將CSS文件放在HEAD標(biāo)簽里,在IE中,@import相當(dāng)于把CSS文件放到了頁面底部,所以最好不用這么使用。
避免使用CSS圖片濾鏡在IE7一下,AlphaImageLoader用于解決PNG圖片透明問題,如果圖片設(shè)置了這個屬性,當(dāng)它在下載時,會阻塞瀏覽器渲染頁面,甚至讓瀏覽器卡死,這個問題是很嚴(yán)重。
可緩存的favicon.icofavicon.ico是網(wǎng)站根目錄的一張圖片,即便你不在HTML中設(shè)置它,瀏覽器也會發(fā)出請求,并且?guī)螩ookie等信息。
想要較少favicon.ico帶來的不良影響,需要做到:
1. 文件小,最好在1K一下
2. 在HTTP header中設(shè)置適當(dāng)?shù)倪^期時間(Expires)
空的圖片src屬性有三種形式:
HTML
CSS
.class{background:url("")}
JS
var img = new Image(); img.src = "";
這么做各瀏覽器發(fā)出請求情況各有差異,具體如下:
* IE會向頁面的目錄發(fā)出請求;
* Safari和Chrome會向當(dāng)前頁面自己發(fā)出請求;
* Firefox 3及一下版本和Safari一樣,向當(dāng)前頁面自己發(fā)出請求;
* Firefox 4及以上版本和Opera不發(fā)出請求;
本文粗譯自http://developer.yahoo.com/performance/rules.html,有所刪減并加了很多自己的理解。如果有錯誤或不恰當(dāng)?shù)牡胤剑瑲g迎指正。
有些知識點只是粗描淡寫,比如靜態(tài)資源并行下載數(shù)、@import各瀏覽器表現(xiàn)差異等,歡迎在評論中詳細討論。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/49460.html
摘要:最少化請求用戶在瀏覽網(wǎng)頁時,超過的時間都是在請求下載網(wǎng)頁資源,包括圖片,樣式,腳本,等等,減少這些資源的下載請求數(shù)目,便成了讓網(wǎng)頁提速的關(guān)鍵。但需要提的是,中對請求的長度限制在字節(jié)以內(nèi)參考,所以如果超過這個長度,只能使用請求。 前端工程師常常被提起網(wǎng)站性能,如何讓網(wǎng)站訪問更快等問題,本文就做個總結(jié)。 最少化HTTP請求 用戶在瀏覽網(wǎng)頁時,超過80%的時間都是在請求下載網(wǎng)頁資源,包括...
摘要:最初,也在使用,并且最初看來功能安好。和的區(qū)別最大的區(qū)別在于托管于而不是。存在的問題在使用中,我們發(fā)現(xiàn)存在的問題主要表現(xiàn)在兩方面。使用考慮到的獨立性,我們設(shè)計了一個來管理所有,并使用和建立通訊。 在 FoxOne 1.5.1 版更新中,打開各個交易所網(wǎng)頁的速度得到了巨大提升。 我們分別在不同的網(wǎng)絡(luò)環(huán)境下,測算了新版 FoxOne 在 Dom 加載和頁面加載條件下的所需時間: showI...
摘要:,谷歌給的一份性能指南和最佳實踐。目前而言,前端社區(qū)有三大框架和。隨后重點講述了和兩大前端框架,給出了大量的文章教程和相關(guān)資源列表。我認為,使用函數(shù)式編程方式,更加符合后端程序員的思路,而是更符合前端工程師習(xí)慣的框架。 showImg(https://segmentfault.com/img/bVbjQAM?w=1142&h=640); 這個是我訂閱 陳皓老師在極客上的專欄《左耳聽風(fēng)》...
摘要:,谷歌給的一份性能指南和最佳實踐。目前而言,前端社區(qū)有三大框架和。隨后重點講述了和兩大前端框架,給出了大量的文章教程和相關(guān)資源列表。我認為,使用函數(shù)式編程方式,更加符合后端程序員的思路,而是更符合前端工程師習(xí)慣的框架。 showImg(https://segmentfault.com/img/bVbjQAM?w=1142&h=640); 這個是我訂閱 陳皓老師在極客上的專欄《左耳聽風(fēng)》...
摘要:特意對前端學(xué)習(xí)資源做一個匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進步。 特意對前端學(xué)習(xí)資源做一個匯總,方便自己學(xué)習(xí)查閱參考,和好友們共同進步。 本以為自己收藏的站點多,可以很快搞定,沒想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補充。有錯誤的地方,還請斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應(yīng)和斧正,會及時更新,平時業(yè)務(wù)工作時也會不定期更...
閱讀 1905·2021-11-23 09:51
閱讀 1549·2021-11-19 09:40
閱讀 3221·2021-11-11 11:01
閱讀 1120·2021-09-27 13:34
閱讀 1852·2021-09-22 15:56
閱讀 2136·2019-08-30 15:52
閱讀 1071·2019-08-30 14:13
閱讀 3487·2019-08-30 14:10