網站前端優化

1. 儘量減少 HTTP 請求 (Make Fewer HTTP Requests)

  作爲第一條,可能也是最重要的一條。根據 Yahoo!研究團隊的數據分析,有很大一部分用戶訪問會因爲這一條而取得最大受益。有幾種常見的方法能切實減少 HTTP 請求:

  2. 減少 DNS 查找 (Reduce DNS Lookups)

  必須明確的一點,DNS 查找的開銷是很大的。另外,我倒是覺得這是 Yahoo!所有站點的通病,Yahoo!主站點可能還不夠明顯,一些分站點,存在明顯的類似問題。對於國內站點來說,如果過多的使用了站外的 Widget ,也很容易引起過多的 DNS 查找問題。

  3. 避免重定向 (Avoid Redirects)

  不是絕對的避免,儘量減少。另外,應該注意一些不必要的重定向。比如對 Web 站點子目錄的後面添加個/(Slash),就能有效避免一次重定向。http://www.dbanotes.net/arch 與 http://www.dbanotes.net/arch/ 二者之間是有差異的。如果是 Apache 服務器,通過配置 Alias 或mod_rewrite 或是 DirectorySlash 能夠消除這個問題。

  4. 使得 Ajax 可緩存 (Make Ajax Cacheable)

  響應時間對 Ajax來說至關重要,否則用戶體驗絕對好不到哪裏去。提高響應時間的有效手段就是 Cache 。其它的一些優化規則對這一條也是有效的。

  5. 延遲載入組件 (Post-load Components)

  6. 預載入組件 (Preload Components)

  上面兩條嚴格說來,都是屬於異步 這個思想靈活運用的事兒。

  7. 減少 DOM 元素數量 (Reduce the Number of DOM Elements)

  8. 切分組件到多個域 (Split Components Across Domains)

  主要的目的是提高頁面組件並行下載能力。但不要跨太多域名,否則就和第二條有些衝突了。

  9. 最小化 iframe 的數量 (Minimize the Number of iframes)

  熟悉 SEO 的朋友知道 iframe 是 SEO 的大忌。針對前端優化來說 iframe 有其好處,也有其弊端,一分爲二看問題吧。

  10. 杜絕 http 404 錯誤 (No 404s)

  對頁面鏈接的充分測試加上對 Web 服務器 error 日誌的不斷跟蹤能有效減少 404 錯誤,亦能提升用戶體驗。值得一提的是,CSS 與 Java Script 引起的 404 錯誤因爲定位稍稍”難”一點而往往容易被忽略。

  Web 前端優化最佳實踐之Server篇

  1. 使用 CDN (Use a Content Delivery Network)

  國內 CDN 的普及還不夠。不過我們有獨特的電信、網通之間的問題 ,如果針對這個作優化,基本上也算能收到 CDN 或類似的效果吧(假裝如此)。【Tin 說國內 CDN 用的挺多,看看 CDN 廠商的市場就知道了,還沒走入尋常百姓家】

  2. 添加 Expires 或 Cache-Control 信息頭 (Add an Expires or a Cache-Control Header)

  各個瀏覽器都有針對的方案, Apache 例子【注意:下面的說明例子還不夠精細,具體的環境上還要加一些調整】:

  Conf 代碼

  • ExpiresActive On ExpiresByType image/gif “modification plus 1 weeks”
  • Lighttpd 啓用 mod_expire 模塊 後:
  • $HTTP["url"] =~ “\.(jpg|gif|png)$” { expire.url = ( “” => “access 1 years” ) }
  • Nginx 例子參考:
  • location ~* \.(jpg|gif|png)$ { if (-f $request_filename) { expires max; break; } }

  3. 壓縮內容 (Gzip Components)

  對於絕大多數站點,這都是必要的一步,能有效減輕網絡流量壓力。或許有人擔心對 CPU 壓縮對於 CPU 的影響,放心大膽的整吧,沒事兒。Nginx例子:

  gzip on; gzip_types text/plain text/html text/css ext/javascript;

  另外參見:IIS 如何啓用 Gzip 壓縮?

  4. 設置 Etags (Configure ETags)

  對於 Etag ,可能是多數網站維護者都會忽略的地方。在這一系列優化規則出現之前,可能互聯網上絕大多數站點都對這個問題忽略了。當然,Etag 對多數站點性能的影響並不是很大。除非是面向 RSS 的網站。【看到有朋友批評說寫的簡略,並且說 IE 不支持 ETag。明確說一下:IE 支持 ETag,倒是使用 IIS 要注意相關 Etag Bug。】

  補充:我的意思是”很多網站在不注意的情況下都是打開 Etag 的,而沒有網站關心如何用,消耗資源而不知。並不是說 Etag 不好,合理利用 Etag ,絕對能取得很好的收益.

  5. 儘早刷新 Buffer (Flush the Buffer Early)

  對這一條,琢磨了半天,貌似還是異步的思路。能更好的提升用戶體驗?

  6. 對 AJAX 請求使用 GET 方法 (Use GET for AJAX Requests)

  XMLHttpRequest POST 要兩步,而 GET 只需要一步。但要注意的是在 IE 上 GET 最大能處理的 URL 長度是 2K。

  Web 前端優化最佳實踐之Cookie篇

  1. 縮小 Cookie (Reduce Cookie Size)

  Cookie 是個很有趣的話題。根據 RFC 2109 的描述,每個客戶端最多保持 300 個 Cookie,針對每個域名最多 20 個 Cookie (實際上多數瀏覽器現在都比這個多,比如 Firefox是 50 個),每個 Cookie 最多 4K,注意這裏的 4K 根據不同的瀏覽器可能不是嚴格的 4096 。別扯遠了,對於 Cookie 最重要的就是,儘量控制 Cookie 的大小,不要塞入一些無用的信息。

  2. 針對 Web 組件使用域名無關性的 Cookie (Use Cookie-free Domains for Components)

  這個話題在此前針對 Web 圖片服務器 的討論中曾經提及。這裏說的 Web 組件(Component),多指靜態文件,比如圖片 CSS 等,Yahoo!的靜態文件都在yimg.com 上,客戶端請求靜態文件的時候,減少了 Cookie 的反覆傳輸對主域名(yahoo.com)的影響。

  從這篇 When the Cookie Crumbles 能看出,MySpace 和 eBay的 Cookie 都不小的,想必是對用戶行爲比較關心。eBay前不久構造了 Personalization Platform ,就是從 Cookie 的限制中跳出來。

  Web 前端優化最佳實踐第四部分面向CSS篇

  1. 把 CSS 放到代碼頁上端 (Put Stylesheets at the Top)

  官方的解釋我覺得多少有點語焉不詳。這一條其實和用戶訪問期望有關。CSS 放到最頂部,瀏覽器能夠有針對性的對 HTML 頁面從頂到下進行解析和渲染。沒有人喜歡等待,而瀏覽器已經考慮到了這一點。

  2. 避免 CSS 表達式 (Avoid CSS Expressions)

  個人認爲通過 CSS 表達式能做到的事情,通過其它手段也同樣能做到而且風險更小一些。

  3. 從頁面中剝離 JavaScript 與 CSS (Make JavaScript and CSS External)

  剝離後,能夠有針對性的對其進行單獨的處理策略,比如壓縮或者緩存策略。

  4. 精簡 JavaScript 與 CSS (Minify JavaScript and CSS )

  如果沒有 JavaScript 與 CSS 可能更好。但,這是不可能的,SO,儘量小點吧。語法能簡寫的簡寫。

  5. 使用 <link> 而不是@importChoose <link> over @import

  在 IE 中 @import 指令等同於把 link 標記寫在 HTML 的底部。而這與第一條相違背。

  6. 避免使用Filter (Avoid Filters)

  另請參見 Mozilla 開發者中心的文章:Writing Efficient CSS

  Web 前端優化最佳實踐之JavaScript 篇

  1. 腳本放到 HTML 代碼頁底部 (Put Scripts at the Bottom)

  當一個腳本在下載的時候,瀏覽器幹不了其它的事兒(串行了)。所以,把它扔到最後面去處理。對於一些功能性的腳本,可能實現起來有些兩難。不過對於國內網站來說,有很多使用 Google Analytics 服務進行網站數據分析的。這這一點來說,絕對可行的建議,放到頁面最底下。

  2. Make JavaScript and CSS External

  參見 CSS 篇的描述

  3. 精簡 JavaScript 與 CSS (Minify JavaScript and CSS )

  參見 CSS 篇的描述

  4. 移除重複腳本 (Remove Duplicate Scripts)

  對於一些歷史遺留站點或是論壇類的網站來說,這倒是比較常見的。接手維護人前後變化過多,每個人都有自己的一套。這就會帶來一些潛在的麻煩。

  5. 減少 DOM 訪問 (Minimize DOM Access)

  有三條指導建議:

  • 緩存已經訪問過的元素(Cache references to accessed elements)
  • “ 離線”更新節點,再將它們添加到樹中(Update nodes “offline” and then add them to the tree)
  • 避免使用 JavaScript 輸出頁面佈局–應該是 CSS 的事兒(Avoid fixing layout with JavaScript)

  6. Develop Smart Event Handlers

  除了英文解釋外,這裏也提醒一下注意關於 Java Script 內存泄漏 的問題。

  Web前端優化最佳實踐之圖片篇

  1. 優化圖片 (Optimize Images)

  使用 GIF 、JPG 還是 PNG 格式的圖片? 儘可能的使用 PNG 格式的圖片,更多的功能,更小的尺寸(與 GIF 相比)。

對於 PNG 圖片,考慮用 Pngcrush 或類似的工具進行優化。常見的工具如下表:

  • pngcrush http://pmt.sourceforge.net/pngcrush/
  • pngrewrite http://www.pobox.com/~jason1/pngrewrite/
  • OptiPNG http://www.cs.toronto.edu/~cosmin/pngtech/optipng/(refer: 教程 )
  • PNGOut http://advsys.net/ken/utils.htm

  對 JPEG 圖片的優化工具:

  必需要強調的是,圖片設計的同學啊,請考慮設計面向 Web 的圖片 ,不要動不動就設計超過可接受尺寸之外大傢伙,這應該是一種習慣,而不是什麼高超的技能,只需要記住就成了。

  2. 使用 CSS Sprites 技巧對圖片優化 (Optimize CSS Sprites)

  之前提到過,簡單的說就是”利用 CSS background 相關元素進行背景圖絕對定位”,把多次 HTTP 調用變爲一次調用,更多參考:CSS Sprites: Image Slicing’s Kiss of Death

  補充一下:對於這個技巧我曾經見到有人濫用的。把多個背景圖片揉成一個,減少 HTTP 調用,這是一個很好的思路。但一定要記住這個大圖片不能太”重”,我看到過 100 多K 的背景圖。一個圖片就把整個網站拖得很慢。比較好的例子可以參考雅虎關係的這個圖

  3. 不要在 HTML 中使用縮放圖片 (Don’t Scale Images in HTML )

  更多的時候,可能是因爲偷懶而沒有製作合適大小的圖片,如果是批量處理圖片的話,可能一條 ImageMagic 命令(convert )就能搞定。必須提及的是,看到太多的對圖片拉伸很難看的頁面,救救這些頁面!

  4. 用更小的並且可緩存的 favicon.ico (Make favicon.ico Small and Cacheable)

  更小,可緩存,這兩條可能都不是問題。問題是,太多站點根本沒有 favicon.ico 。有的時候,判斷獨立域名的 Blog 是否專業,基本看一下是否有 favicon.ico 就差不多了。

 

 

 

避免壞死請求

避免CSS @import

避免CSS expressions

避免 document.write

合併外部CSS

合併外部JAVASCRIPT

使用CSS浮標合併圖片

延遲JavaScript加載

延遲JavaScript解析

啓用gzip壓縮

啓用Keep-Alive

將較小的外部CSS,變成內部CSS

將較小的外部JavaScript變成內部的

利用瀏覽器緩存

利用代理緩存(棄用)

緩存頁面登陸重定向

減小CSS

減小HTML

減小JavaScript

減小cookie大小(棄用)

減少DNS查找

減少請求

減少請求大小

優化圖片

優化樣式和腳本的順序

跨域名並行下載

使用異步資源

CSS至於document頭部

移除靜態資源問號

移除沒有用到的CSS

從一個固定的URL提供資源

提供圖片縮放

從無cookie域名提供靜態內容

指定一個緩存驗證器

儘早指定一個字符集

指定一個多樣化的Accept-Encoding 頭部

指定圖片尺寸

使用高效CSS選擇器

 

 

個人感覺比較好着手落實的一些有:調整CSSJavaScript的順序和位置、合併CSSJavaScript、圖片的優化方面、增長圖片等的緩存期限

其他的如提高CSSJavaScript的效率,在後期的優化方面則比較困難,需要在寫代碼的時候進行優化了。

發佈了201 篇原創文章 · 獲贊 0 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章