亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 網頁設計 > 正文

Web 前端性能優化

2024-08-30 08:34:33
字體:
來源:轉載
供稿:網友

Web 前端優化最佳實踐之 內容篇
Web 前端優化最佳實踐之 Server 篇
Web 前端優化最佳實踐之 Cookie 篇
Web 前端優化最佳實踐之 CSS 篇
Web 前端優化最佳實踐之 JavaScript 篇
Web 前端優化最佳實踐之 圖象篇
Web 前端優化最佳實踐之 Mobile(iPhone) 篇

Yahoo! 的 Exceptional Performance team 在 Web 前端方面作出了卓越的貢獻。廣為人知的優化規則也由 13 條到 14 條,再到 20 條,乃至現在的 34 條--真是與時俱進啊。最新的 34 條也針對不同的角度做了分類。

面向內容的優化規則目前有 10 條。

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

•1) 合并文件,比如把多個 CSS 文件合成一個;
•2) CSS Sprites 利用 CSS background 相關元素進行背景圖絕對定位;參見:CSS Sprites: Image Slicing's Kiss of Death
•3) 圖像地圖
•4) 內聯圖象 使用 data: URL scheme 在實際的頁面嵌入圖像數據.
2. 減少 DNS 查找 (Reduce DNS Lookups)
    必須明確的一點,DNS 查找的開銷是很大的。另外,我倒是覺得這是 Yahoo! 所有站點的通病,Yahoo!主站點可能還不夠明顯,一些分站點,存在明顯的類似問題。對于國內站點來說,如果過多的使用了站外的 Widget ,也很容易引起過多的 DNS 查找問題。

3. 避免重定向 (Avoid Redirects)
     不是絕對的避免,盡量減少。另外,應該注意一些不必要的重定向。比如對 Web 站點子目錄的后面添加個 / (Slash) ,就能有效避免一次重定向。http://www.dbanotes.net/archhttp://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 錯誤因為定位稍稍"難"一點而往往容易被忽略。

這是內容篇的 10 條。應該說具體引導性的內容還不夠詳細。逐漸會根據自己的理解補充上來。


網頁制作poluoluo文章簡介:Web 前端性能優化是個大話題,是個值得運維人員持續跟蹤的話題,是被很多網站無情忽視的技術。

Web 前端優化最佳實踐第二部分面向 Server 。

目前共計有 6 條實踐規則?!咀?,這最多算技術筆記,查看最原始內容,還請訪問:Exceptional Performance : Best Practices for Speeding Up Your Web Site 】

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 例子【注意:下面的說明例子還不夠精細,具體的環境上還要加一些調整】:

ExpiresActive On
ExpiresByType image/gif "modification plus 1 weeks"Lighttpd 啟用 mod_expire 模塊 后:

$HTTP["url"] =~ "/.(jpg|gif|png)___FCKpd___1quot; {
     expire.url = ( "" => "access 1 years" )
}Nginx 例子參考:

location ~* /.(jpg|gif|png)$ {
  if (-f $request_filename) {
        expires      max;
    break;
  }       
}

3. 壓縮內容 (Gzip Components)
對于絕大多數站點,這都是必要的一步,能有效減輕網絡流量壓力?;蛟S有人擔心對 CPU 壓縮對于 CPU 的影響,放心大膽的整吧,沒事兒。Nginx 例子:

gzip            on;
gzip_types      text/plain text/html text/css ext/javascript;另外參見:

IIS 如何啟用 Gzip 壓縮?
4. 設置 Etags (Configure ETags)
對于 Etag,可能是多數網站維護者都會忽略的地方。在這一系列優化規則出現之前,可能互聯網上絕大多數站點都對這個問題忽略了。當然,Etag 對多數站點性能的影響并不是很大。除非是面向 RSS 的網站?!究吹接信笥雅u說寫的簡略,并且說 IE 不支持 ETag。明確說一下:IE 支持 ETag,倒是使用 IIS 要注意相關 Etag Bug?!?/p>

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

5. 盡早刷新 Buffer (Flush the Buffer Early)
對這一條,琢磨了半天,貌似還是異步的思路。能更好的提升用戶體驗?

6. 對 AJAX 請求使用 GET 方法 (Use GET for AJAX Requests)
XMLHttpRequest POST 要兩步,而 GET 只需要一步。但要注意的是在 IE 上 GET 最大能處理的 URL 長度是 2K。


網頁制作poluoluo文章簡介:Web 前端性能優化是個大話題,是個值得運維人員持續跟蹤的話題,是被很多網站無情忽視的技術。


Web 前端優化最佳實踐第三部分面向 Cookie 。目前只有 2 條實踐規則。

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 的限制中跳出來。


網頁制作poluoluo文章簡介:Web 前端性能優化是個大話題,是個值得運維人員持續跟蹤的話題,是被很多網站無情忽視的技術。


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

目前共計有 6 條實踐規則。另請參見 Mozilla 開發者中心的文章:Writing Efficient 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)

網頁制作poluoluo文章簡介:Web 前端性能優化是個大話題,是個值得運維人員持續跟蹤的話題,是被很多網站無情忽視的技術。


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

這部分有 6 條規則,和 CSS 篇 重復的有幾條。前端優化最佳實踐,最重要的還是"實踐",要理解這東西容易得很,關鍵是要去"實踐",去"執行",去"反饋",去獲取受益。

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 內存泄漏的問題。

另外推薦一篇《如何優化 JavaScript 腳本的性能》,關于 Ajax 優化指導原則,可以參見 提高 Ajax 應用程序性能,避開 Web 服務漏洞。

后記1) :整理得差不多之后,發現網絡上已經有一篇 《Yahoo!網站性能最佳體驗的34條黃金守則》,是翻譯稿。看來我做了一部分重復勞動。

后記 2):CSS / JavaScript 都有優化規則。但似乎缺少了對 Flash 的優化實踐。


網頁制作poluoluo文章簡介:Web 前端性能優化是個大話題,是個值得運維人員持續跟蹤的話題,是被很多網站無情忽視的技術。


Web 前端優化最佳實踐第六部分面向 圖片(Image)

這部分目前有 4 條規則。在最近的 Velocity 2008 技術大會上,Yahoo! 的 Stoyan Stefanov 做的 Image Optimization: How Many of These 7 Mistakes Are You Making 也非常有參考價值。結合一起說一下。

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
另請參見: Five Tips For the Effective Use of PNG Images

對 JPEG 圖片的優化工具:

•jpegtran (http://jpegclub.org/)
必需要強調的是,圖片設計的同學啊,請考慮設計面向 Web 的圖片,不要動不動就設計超過可接受尺寸之外大家伙,這應該是一種習慣,而不是什么高超的技能,只需要記住就成了。

2. 使用 CSS Sprites 技巧對圖片優化 (Optimize CSS Sprites)
之前提到過,簡單的說就是"利用 CSS background 相關元素進行背景圖絕對定位",把多次 HTTP 調用變為一次調用,更多參考:CSS Sprites: Image Slicing's Kiss of Death

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

更新:使用 CSS Sprites 的一個潛在的副作用是客戶端將消耗更多內存(參考)。

3. 不要在 HTML 中使用縮放圖片 (Don't Scale Images in HTML)
更多的時候,可能是因為偷懶而沒有制作合適大小的圖片,如果是批量處理圖片的話,可能一條 ImageMagic 命令(convert )就能搞定 。必須提及的是,看到太多的對圖片拉伸很難看的頁面,救救這些頁面!

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

--EOF--

補充:視覺設計者應該盡量考慮控制圖片大小,推薦在 200K 以下。這不是胡說的,參考頁面。


網頁制作poluoluo文章簡介:Web 前端性能優化是個大話題,是個值得運維人員持續跟蹤的話題,是被很多網站無情忽視的技術。


Web 前端優化最佳實踐最后一部分是針對移動應用的,其實只是針對 iPhone 的,目前只有兩條規則。

1. 單個數據對象小于 25K (Keep Components under 25K)
這個似乎只是針對 iPhone 研究的。建議保持單個 Web 數據對象在 25 K 以下。為什么是 25K? Apple 官方信息指出可緩存到內存中的 Web 對象最大支持到 10M,但經過測試,發現也就是 25K 左右。

iPhone 在市場上的優異表現,讓 Web 人員不得不考慮如何針對其進行優化。相信這部分內容也在不斷變化中。

2. Pack Components into a Multipart Document
把Web 頁面組件打包成一個多部分組成的文檔。其目的是減少 HTTP 請求。對這部分語焉不詳,等待后續更新吧。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产乱码久久久久久久久| 国产精品久久久久久久久久小说| 欧美亚洲激情视频| 久久av中文字幕| 亚洲精品一区在线观看香蕉| 亚洲男女自偷自拍图片另类| 黑人巨大精品欧美一区免费视频| 中文字幕亚洲欧美日韩2019| 国产欧美在线视频| 91精品国产自产在线观看永久| 一本色道久久综合狠狠躁篇怎么玩| 国产成人jvid在线播放| 亚洲www视频| 精品视频中文字幕| 疯狂做受xxxx欧美肥白少妇| 中文字幕精品av| 久久亚洲私人国产精品va| 色阁综合伊人av| 欧美另类69精品久久久久9999| 欧美日韩在线视频首页| 国产日韩在线看| 日韩精品电影网| 国产精品高精视频免费| 欧美一级片在线播放| 88国产精品欧美一区二区三区| 欧美日韩国产页| 亚洲va码欧洲m码| 中文字幕久久久av一区| 色噜噜国产精品视频一区二区| 亚洲一区二区三区乱码aⅴ| 国产精品一区久久| 欧美黑人一级爽快片淫片高清| 国产999精品久久久影片官网| 亚洲天堂免费在线| 久久精品国产精品亚洲| 欧美性少妇18aaaa视频| 亚洲欧美制服第一页| 亚洲天堂第二页| 欧美日韩福利在线观看| 国产精品福利在线观看| 日韩国产激情在线| 一区二区在线视频播放| 色yeye香蕉凹凸一区二区av| 亚洲va国产va天堂va久久| 亚洲激情视频在线播放| 精品偷拍各种wc美女嘘嘘| 日韩精品中文在线观看| 97视频国产在线| 久久久久久久久久久久久久久久久久av| 92看片淫黄大片欧美看国产片| 91精品中国老女人| 欧美色videos| 日韩中文字幕精品视频| 欧美国产亚洲精品久久久8v| 久久在线免费观看视频| 久久精品视频在线| 茄子视频成人在线| 中文字幕在线观看亚洲| 欧美黑人又粗大| 亚洲精品www久久久| 成人午夜激情免费视频| 亚洲最大的av网站| 欧美成人国产va精品日本一级| 国产网站欧美日韩免费精品在线观看| 在线播放国产一区二区三区| 正在播放国产一区| 国产精品久久久久久久午夜| 欧美大片在线看| 青草青草久热精品视频在线观看| 国产日韩欧美中文| www.日韩视频| 日韩亚洲欧美中文高清在线| 亚洲图片制服诱惑| 欧美视频不卡中文| 亚洲精品美女网站| 红桃视频成人在线观看| www.日韩不卡电影av| 亚洲最大av网站| 亚洲精品久久久久中文字幕欢迎你| 亚洲成人黄色网址| 97色在线视频观看| 日韩精品亚洲元码| 91精品久久久久| 亚洲区在线播放| 久热99视频在线观看| 性欧美亚洲xxxx乳在线观看| 91精品综合视频| 欧美大片在线看| 欧美性在线视频| 国产精品美女在线| 国产日韩换脸av一区在线观看| 欧美成aaa人片免费看| 亚洲成人1234| 欧美贵妇videos办公室| 日韩av高清不卡| 国产精品久久久久久久久久久久久| 日韩av在线不卡| 欧美国产日韩视频| 国产精品日韩欧美综合| 久久免费少妇高潮久久精品99| 久久久亚洲国产天美传媒修理工| 亚洲精品一区中文字幕乱码| 国产视频福利一区| 欧美日韩国产专区| 国产中文字幕亚洲| 欧美成人在线免费| 97视频在线观看免费高清完整版在线观看| 久久手机免费视频| 国产精品露脸自拍| 黄网站色欧美视频| 91色中文字幕| 91po在线观看91精品国产性色| 精品久久久久久中文字幕一区奶水| 在线观看欧美视频| 91香蕉嫩草神马影院在线观看| 狠狠躁夜夜躁久久躁别揉| 91夜夜未满十八勿入爽爽影院| 日韩福利在线播放| 久久免费视频这里只有精品| 久久久亚洲网站| 中文字幕亚洲欧美日韩高清| 自拍亚洲一区欧美另类| 午夜精品一区二区三区在线| 欧美理论电影在线播放| 九九视频直播综合网| 俺去亚洲欧洲欧美日韩| 日韩电影中文字幕一区| 国产国语videosex另类| 久久理论片午夜琪琪电影网| 久久精品国产清自在天天线| 久久99国产精品自在自在app| 在线看日韩欧美| 91久久精品日日躁夜夜躁国产| 亚洲色图欧美制服丝袜另类第一页| 国产69精品99久久久久久宅男| 日本免费一区二区三区视频观看| 日韩精品丝袜在线| 亚洲国产91色在线| 欧美俄罗斯性视频| 最新69国产成人精品视频免费| 日韩精品小视频| 456亚洲影院| 中文字幕日韩av综合精品| 奇米影视亚洲狠狠色| 日韩欧美国产激情| 欧美xxxwww| 97在线精品国自产拍中文| 欧美高清在线视频观看不卡| 日韩欧美亚洲范冰冰与中字| 日韩免费黄色av| 亚洲激情视频在线播放| 91av视频在线| 国产不卡在线观看| 日韩视频―中文字幕| 狠狠久久五月精品中文字幕| 国产成人短视频| 欧美日韩在线另类| 国产欧美日韩高清| 亚洲成人久久久| 成人黄色生活片| 96国产粉嫩美女| 成人国产精品av| 亚洲aa中文字幕| 国产在线精品成人一区二区三区|