摘要:前端優(yōu)化是復(fù)雜的,針對方方面面的資源都有不同的方式。前端性能優(yōu)化前端性能團隊總結(jié)的條黃金定律的團隊總結(jié)出了一系列可以提高網(wǎng)站速度的方法。提高性能的措施中最重要的方法就是使響應(yīng)具有可緩存性。
前端是龐大的,包括 HTML、 CSS、 Javascript、Image 、Flash等等各種各樣的資源。前端優(yōu)化是復(fù)雜的,針對方方面面的資源都有不同的方式。那么,前端優(yōu)化的目的是什么 ?Tips:個人博客排版、UI更佳;地址:https://haonancx.github.io/
從用戶角度而言,優(yōu)化能夠讓頁面加載得更快、對用戶的操作響應(yīng)得更及時,能夠給用戶提供更為友好的體驗。
從服務(wù)商角度而言,優(yōu)化能夠減少頁面請求數(shù)、或者減小請求所占帶寬,能夠節(jié)省可觀的資源。
總之,恰當?shù)膬?yōu)化不僅能夠改善站點的用戶體驗并且能夠節(jié)省相當?shù)馁Y源利用。
前端性能優(yōu)化 - Yahoo前端性能團隊總結(jié)的35條黃金定律盡量減少 HTTP 請求
減少 DNS 查找
避免跳轉(zhuǎn)
緩存 Ajax
推遲加載
提前加載
減少 DOM 元素數(shù)量
用域名劃分頁面內(nèi)容
使 frame 數(shù)量最少
避免404錯誤
服務(wù)器部分合并文件是通過把所有的腳本放到一個文件中來減少 HTTP請求的方法。
CSS Sprites是減少圖像請求的有效方法。
緩存 DNS查找可以改善頁面性能。
跳轉(zhuǎn)是使用 301和 302代碼實現(xiàn)的(但是要記住跳轉(zhuǎn)會降低用戶體驗)。
為了提高性能,優(yōu)化 Ajax響應(yīng)是很重要的。提高 Ajxa性能的措施中最重要的方法就是使響應(yīng)具有可緩存性。
你可以仔細看一下你的網(wǎng)頁,問問自己“哪些內(nèi)容是頁面呈現(xiàn)時所必需首先加載的?哪些內(nèi)容和結(jié)構(gòu)可以稍后再加載?預(yù)加載和后加載看起來似乎恰恰相反,但實際上預(yù)加載是為了實現(xiàn)另外一種目標。預(yù)加載是在瀏覽器空閑時請求將來可能會用到的頁面內(nèi)容(如圖像、樣式表和腳 本)。使用這種方法,當用戶要訪問下一個頁面時,頁面中的內(nèi)容大部分已經(jīng)加載到緩存中了,因此可以大大改善訪問速度。
一個復(fù)雜的頁面意味著需要下載更多數(shù)據(jù),同時也意味著JavaScript遍歷DOM的效率越慢。比如當你增加一個事件句柄時在500和5000個 DOM元素中循環(huán)效果肯定是不一樣的。
把頁面內(nèi)容劃分成若干部分可以使你最大限度地實現(xiàn)平行下載。
使iframe的數(shù)量最小,ifrmae元素可以在父文檔中插入一個新的HTML文檔。了解iframe的工作理然后才能更加有效地使用它,這一點很重要。
HTTP請求時間消耗是很大的,因此使用HTTP請求來獲得一個沒有用處的響應(yīng)(例如404沒有找到頁面)是完全沒有必要的,它只會降低用戶體驗而不會有一點好處。
使用內(nèi)容分發(fā)網(wǎng)絡(luò)
為文件頭指定 Expires 或 Cache-Control
Gzip壓縮文件內(nèi)容
配置ETag
盡早刷新輸出緩沖
使用 GET 來完成 AJAX 請求
避免空的圖像來源
CSS部分用戶與你網(wǎng)站服務(wù)器的接近程度會影響響應(yīng)時間的長短。把你的網(wǎng)站內(nèi)容分散到多個、處于不同地域位置的服務(wù)器上可以加快下載速度。
為文件頭指定Expires或Cache-Control,這條守則包括兩方面的內(nèi)容: 對于靜態(tài)內(nèi)容:設(shè)置文件頭過期時間Expires的值為“Never expire”(永不過期);對于動態(tài)內(nèi)容:使用恰當?shù)腃ache-Control文件頭來幫助瀏覽器進行有條件的請求。
網(wǎng)絡(luò)傳輸中的HTTP請求和應(yīng)答時間可以通過前端機制得到顯著改善。的確,終端用戶的帶寬、互聯(lián)網(wǎng)提供者、與對等交換點的靠近程度等都不是網(wǎng)站開發(fā)者所能決定的。但是還有其他因素影響著響應(yīng)時間。通過減小HTTP響應(yīng)的大小可以節(jié)省HTTP響應(yīng)時間。
Entity tags(ETags)(實體標簽)是web服務(wù)器和瀏覽器用于判斷瀏覽器緩存中的內(nèi)容和服務(wù)器中的原始內(nèi)容是否匹配的一種機制(“實體”就是所說的“內(nèi) 容”,包括圖片、腳本、樣式表等)。增加ETag為實體的驗證提供了一個比使用“l(fā)ast-modified date(上次編輯時間)”更加靈活的機制。
當用戶請求一個頁面時,無論如何都會花費200到500毫秒用于后臺組織HTML文件。(盡早刷新輸出緩沖)。
Yahoo!Mail團隊發(fā)現(xiàn),當使用XMLHttpRequest時,瀏覽器中的POST方法是一個“兩步走”的過程:首先發(fā)送文件頭,然后才發(fā)送數(shù) 據(jù)。因此使用GET最為恰當,因為它只需發(fā)送一個TCP包(除非你有很多cookie)。IE中URL的最大長度為2K,因此如果你要發(fā)送一個超過2K的 數(shù)據(jù)時就不能使用GET了。
把樣式表置于頂部
避免使用 CSS 表達式()
用 代替 @import
避免使用濾鏡
內(nèi)會使頁面有步驟的加載顯示。在研究Yahoo!的性能表現(xiàn)時,我們發(fā)現(xiàn)把樣式表放到文檔的
避免使用CSS表達式(Expression),CSS表達式是動態(tài)設(shè)置CSS屬性的強大(但危險)方法。Internet Explorer從第5個版本開始支持CSS表達式。
對于擁有較大瀏覽量的首頁來說,有一種技術(shù)可以平衡內(nèi)置代碼帶來的HTTP請求減少與通過使用外部文件進行緩存帶來的好處。
(削減JavaScript和CSS)精簡是指從去除代碼不必要的字符減少文件大小從而節(jié)省下載時間。消減代碼時,所有的注釋、不需要的空白字符(空格、換行、tab縮進)等都要去掉。
前面的最佳實現(xiàn)中提到CSS應(yīng)該放置在頂端以利于有序加載呈現(xiàn)。在IE中,頁面底部@import和使用作用是一樣的,因此最好不要使用它。
IE獨有屬性AlphaImageLoader用于修正7.0以下版本中顯示PNG圖片的半透明效果。這個濾鏡的問題在于瀏覽器加載圖片時它會終止內(nèi)容的 呈現(xiàn)并且凍結(jié)瀏覽器。在每一個元素(不僅僅是圖片)它都會運算一次,增加了內(nèi)存開支,因此它的問題是多方面的。
JavaScript部分把腳本置于頁面底部
使用外部 JavaScript 和 CSS
削減 JavaScript 和 CSS
剔除重復(fù)腳本
減少DOM訪問
開發(fā)智能事件處理程序
Coockie部分腳本帶來的問題就是它阻止了頁面的平行下載。HTTP/1.1 規(guī)范建議,瀏覽器每個主機名的并行下載內(nèi)容不超過兩個。一個經(jīng)常用到的替代方法就是使用延遲腳本。
在同一個頁面中重復(fù)引用JavaScript文件會影響頁面的性能。你可能會認為這種情況并不多見。對于美國前10大網(wǎng)站的調(diào)查顯示其中有兩家存在重復(fù)引 用腳本的情況。有兩種主要因素導致一個腳本被重復(fù)引用的奇怪現(xiàn)象發(fā)生:團隊規(guī)模和腳本數(shù)量。
使用JavaScript訪問DOM元素比較慢,因此為了獲得更多的應(yīng)該頁面,應(yīng)該做到:緩存已經(jīng)訪問過的有關(guān)元素,線下更新完節(jié)點之后再將它們添加到文檔樹中,避免使用JavaScript來修改頁面布局,有關(guān)此方面的更多信息請查看Julien Lecomte在YUI專題中的文章“高性能Ajax應(yīng)該程序”。
有時候我們會感覺到頁面反應(yīng)遲鈍,這是因為DOM樹元素中附加了過多的事件句柄并且些事件句病被頻繁地觸發(fā)。這就是為什么說使用event delegation(事件代理)是一種好方法了。
減小Cookie體積
對于頁面內(nèi)容使用無coockie域名
Image 部分coockie 是通過HTTP文件頭來在web服務(wù)器和瀏覽器之間進行交流的。去除不必要的coockie,使coockie體積盡量小以減少對用戶響應(yīng)的影響,注意在適應(yīng)級別的域名上設(shè)置coockie以便使子域名不受影響;設(shè)置合理的過期時間。較早地Expire時間和不要過早去清除coockie,都會改善用戶的響應(yīng)時間。
對于頁面內(nèi)容使用無coockie域名,當瀏覽器在請求中同時請求一張靜態(tài)的圖片和發(fā)送coockie時,服務(wù)器對于這些coockie不會做任何地使用。因此他們只是因為某些負面因素而創(chuàng)建的 網(wǎng)絡(luò)傳輸。所有你應(yīng)該確定對于靜態(tài)內(nèi)容的請求是無coockie的請求。創(chuàng)建一個子域名并用他來存放所有靜態(tài)內(nèi)容。
優(yōu)化圖像
優(yōu)化 CSS Spirite
不要在 HTML 中縮放圖像
favicon.ico 要小而且可緩存
優(yōu)化圖像和CSS Spirite,在Spirite中水平排列你的圖片,垂直排列會稍稍增加文件大?。籗pirite 中把顏色較近的組合在一起可以降低顏色數(shù),理想狀況是低于256色以便適用PNG8格式;
favicon.ico是位于服務(wù)器根目錄下的一個圖片文件。它是必定存在的,因為即使你不關(guān)心它是否有用,瀏覽器也會對它發(fā)出請求,因此最好不要返回一 個404 Not Found的響應(yīng)。
七、 Mobile部分
保持單個內(nèi)容小于25K
打包組件成復(fù)合文本
是不是感覺挺多的,這還只是優(yōu)化方案的概括,細分起來還有很多細節(jié)。 好了, 今天就到這兒,下篇文章見。 該文章部分知識網(wǎng)絡(luò)整理保持單個內(nèi)容小于25K,這條限制主要是因為iPhone不能緩存大于25K的文件。注意這里指的是解壓縮后的大小。由于單純gizp壓縮可能達不要求,因此精簡文件就顯得十分重要。
打包組件成復(fù)合文本,把頁面內(nèi)容打包成復(fù)合文本就如同帶有多附件的Email,它能夠使你在一個HTTP請求中取得多個組件(切記:HTTP請求是很奢侈的)。當你使用這條規(guī)則時,首先要確定用戶代理是否支持(iPhone就不支持)。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/115389.html
摘要:前端優(yōu)化是復(fù)雜的,針對方方面面的資源都有不同的方式。前端性能優(yōu)化前端性能團隊總結(jié)的條黃金定律的團隊總結(jié)出了一系列可以提高網(wǎng)站速度的方法。提高性能的措施中最重要的方法就是使響應(yīng)具有可緩存性。 前端是龐大的,包括 HTML、 CSS、 Javascript、Image 、Flash等等各種各樣的資源。前端優(yōu)化是復(fù)雜的,針對方方面面的資源都有不同的方式。那么,前端優(yōu)化的目的是什么 ?Tips...
摘要:前端優(yōu)化是復(fù)雜的,針對方方面面的資源都有不同的方式。前端性能優(yōu)化前端性能團隊總結(jié)的條黃金定律的團隊總結(jié)出了一系列可以提高網(wǎng)站速度的方法。提高性能的措施中最重要的方法就是使響應(yīng)具有可緩存性。 前端是龐大的,包括 HTML、 CSS、 Javascript、Image 、Flash等等各種各樣的資源。前端優(yōu)化是復(fù)雜的,針對方方面面的資源都有不同的方式。那么,前端優(yōu)化的目的是什么 ?Tips...
摘要:雖然如此,但是網(wǎng)站前端性能優(yōu)化的思路基本沒變。為什么前端性能如此重要數(shù)據(jù)顯示只有的最終用戶響應(yīng)時間花在了下載文檔上。前端性能優(yōu)化一味奉行最佳實踐有時候反而過而不及,所以針對項目的實際情況來優(yōu)化才是明智的選擇。 前端近幾年變化很大,各種工具,庫,框架并發(fā)。雖然如此,但是網(wǎng)站前端性能優(yōu)化的思路基本沒變。為什么前端性能如此重要?數(shù)據(jù)顯示: 只有 10%~20% 的最終用戶響應(yīng)時間花在了下載...
打算現(xiàn)在開始在博客里寫點東西,也能為自己看過的書學過的知識做一個歸納總結(jié)。這幾日拜讀了Steve Souders的《高性能網(wǎng)站建設(shè)指南這本書》,雖然這本書可能已經(jīng)有些老了,但薄薄的一個小冊子里提出的網(wǎng)站性能優(yōu)化的準則還是非常有價值的。這些規(guī)則都有個共同點,就是用很小的工作就能獲得很明顯的性能提升,性價比極高。廢話不多說了,總結(jié)一下書里的幾點性能優(yōu)化規(guī)則。 首先有一點需要說明的是書中所寫的性能黃金法...
摘要:開放封閉原則應(yīng)該算是這幾個原則里面最容易理解的一個。另外,語句就是開放封閉原則的死敵這個是狀態(tài)模式中的一個例子。處理開放封閉模式的特例我們都是人,不可能一開始都寫出完美的代碼。 開放-封閉原則應(yīng)該算是這幾個原則里面最容易理解的一個。它的宗旨就是:如果你想擴展或者改變一個程序的功能,可以增加代碼,但是不能改變程序的源碼。如果,是對于那些碼農(nóng)來說,最快捷的辦法就是改變源碼,但是我們面向的是...
閱讀 3531·2021-11-24 09:39
閱讀 788·2019-08-30 14:22
閱讀 3042·2019-08-30 13:13
閱讀 2326·2019-08-29 17:06
閱讀 2927·2019-08-29 16:22
閱讀 1263·2019-08-29 10:58
閱讀 2439·2019-08-26 13:47
閱讀 1639·2019-08-26 11:39