現 在愈來愈多的圖片,腳本,css,flash被嵌入到頁面中,當咱們訪問他們的時候勢必會作許屢次的http請求。其實咱們能夠經過設置 Expires header 來緩存這些文件。Expire其實就是經過header報文來指定特定類型的文件在覽器中的緩存時間。大多數的圖片,flash在發佈後都是不須要常常修 改的,作了緩存之後這樣瀏覽器之後就不須要再從服務器下載這些文件而是而直接從緩存中讀取,這樣再次訪問頁面的速度會大大加快。 php
另外,除了以上的yahoo十四條軍規外,還可使用以下三條優化建議:css
高性能HTML
1、避免使用iframe
iframe也叫內聯frame,可將一個HTML文檔嵌入另外一個HTML文檔中。
iframe的好處是,嵌入的文檔獨立於父文檔,一般也藉此使瀏覽器模擬多線程。缺點是:
①雖然iframe能模擬多線程,但主流瀏覽器的同域名並行下載數是不變的,瀏覽器對同域名的連接老是共享瀏覽器級別的鏈接池,
即便是不一樣窗口或標籤頁的同域名網頁。
②在頁面加載時,iframe會阻塞父文檔onload事件的觸發。而且有些瀏覽器需在觸發onload事件後才能被觸發onunload事件。
故用戶用onload事件長久未觸發而離開頁面時,不會觸發onunload事件。
※不兼容IE6~8的解決方案:使用JavaScript動態加載iframe元素或動態設置其src屬性。
html
③iframe是文檔內最消耗資源的元素之一,即便是空iframe的開銷也是昂貴的。【經過Steve Souders測試】
2、避免空鏈接屬性
空鏈接指:img、link、script 和 iframe元素的src或href屬性的值爲空。(如src = 」」)
設置了空鏈接後瀏覽器依然會以默認規則發送請求:
①IE6~8中只有img元素會出問題:IE會將img的空地址解析爲當前頁面地址的目錄地址並請求。
如當前網頁地址爲http://aaa.com/bb/c.html,img的地址會被解析爲http://aaa.com/bb
②早些版本的Webkit和Firefox會將空鏈接解析爲當前頁面的地址。在ios與android中此問題較嚴重。
若是頁面有多個空鏈接屬性元素,會增長服務器的請求次數。
③幸運的是,主流瀏覽器對iframe的src屬性值爲空時,會解析爲about:blank地址,而不發送額外請求。
3、避免節點深層級嵌套
層級越深的節點在初始化構建時,所佔內存越多。
經過瀏覽器HTML解析器會將整個HTML文檔的結構存儲爲DOM樹結構。當節點嵌套層次越深,構建的DOM書層次也越深。
4、縮減HTML文檔大小
①刪除對執行結果無影響的空格空行和註釋;
②避免table佈局;
③使用HTML5;
五。顯式指定文檔字符集
在HTML頁面開時指定字符集有助於瀏覽器當即開始解析HTML代碼。
HTML文檔一般被解析爲一序列的帶字符集編碼信息的字符串,經過Internet傳送。
字符集編碼在HTTP響應頭中,或HTML標記中指定。瀏覽器經過指定的字符集,吧編碼解析爲可現實在屏幕上的字符。
若瀏覽器沒法獲知頁面的編碼字符集,通常會在執行腳本和渲染頁面以前,先將字節流緩存,再搜索可進行解析的字符集 或 以默認字符集來解析。
6、顯示設置圖片的寬高
有時須要在頁面加載完以前,就對頁面佈局進行定位。
若頁面中的圖片沒指定尺寸,或尺寸與實際圖片大小不符,瀏覽器會在圖片下載完成後再"回溯"該圖片並從新顯示,從而浪費時間。
故最好爲頁面的圖片設置指定尺寸(行內樣式或CSS樣式)。
java
7、避免 腳本阻塞加載
瀏覽器在解析常規script標籤時,會等待script下載完畢後,才解析執行,以後的HTML代碼就只能等待。
故應該將腳本放在文檔的末尾:
linux
1、避免使用@import
CSS2.1加入的@import,會使頁面在加載時添加額外延遲。
因爲瀏覽器不能並行下載樣式,會致使頁面增添額外的往返耗時。而使用<link>能並行下載樣式,但任然是屢次請求。
2、避免AlphaImageLoader濾鏡
此濾鏡能解決IE6即一下版本顯示PNG圖片的半透明效果,但會在加載圖片時終止內容的呈現,並凍結瀏覽器。
在每一個元素(不只僅是圖片)都會運算一次,添加內存開支。
應使用PNG8格式來代替,或用下劃線(_filter)只針對IE6。
3、避免CSS表達式
CSS表達式是設置動態CSS屬性的即強調又危險的方法。IE5開始支持,IE獨有。
//實現每隔一小時切換一次背景顏色android
background-color: expression((new Date()).getHours()%2?"#FFFFFF": "#000000" );ios
CSS表達式的缺點是技術頻率極大,在頁面顯示、縮放、滾動 或 移動鼠標,都會從新計算一次。移動隨便會達到1w次以上的計算量。
①使用一次性的表達式能減小計算次數,在第一次運行時將結果賦給指定樣式屬性,並用該屬性代替CSS表達式。
②若是樣式屬性必須在頁面週期內動態地改變,使用時間句柄代替CSS表達式是一個可行的辦法。
4、避免通配選擇器
優化選擇器的原則是減小匹配時間。CSS選擇器的匹配機制是:從右向左進行規制匹配的!
#header > a { font-weight:blod; }
上面這條規制實際是瀏覽器遍歷頁面全部a元素,並肯定其父元素的id是否爲header。
#header a {...}
後代選擇器開銷更大,在遍歷頁面的全部a元素後,會需向上遍歷直到根節點。
由此可知,選擇器最右邊的規制 每每決定了向左移匹配的工做量。故最右邊的選擇規則 稱之爲關鍵選擇器。
.selected * {...}
在匹配全部元素後,再分別向上匹配直至根節點。一般比開銷最小的ID選擇器高出·~3個數量級。
5、避免單規則的屬性選擇器
.selected [href='#index'] {...}
瀏覽器先匹配全部的元素,檢查其是否有href屬性而且值爲「#index」,再分別向上匹配class爲selected的元素。
故應該避免使用關鍵選擇器是單規則屬性選擇器的規則。
6、避免正則的屬性選擇器
CSS3添加了複雜的屬性選擇器,經過類正則表達式進行匹配。但這些類型的選擇器會比基於類別的匹配慢不少。
7、移除無匹配的樣式
①刪除無用的樣式,可縮減樣式文件大小,加快加載速度。
②對於瀏覽器,全部樣式規則都會被解析後索引發來,即便是當前頁面無匹配的規則!故移除無匹配的規則,減小索引項,加快瀏覽器查找速度。
高性能JavaScript
1、使用事件代理
當過多的時間句柄被頻繁觸發時,頁面反應會遲鈍。
如一個div有10個按鈕,只需給div附加一次事件句柄,而沒必要給每一個按鈕添加一個句柄。
事件冒泡時刻捕捉到事件 並判斷時那個事件發出的。【觸發事件的元素 = ev.srcElement ? ev.srcElement : ev.target;】
2、緩存選擇器查詢結果
減小選擇器查詢的次數,並儘量緩存選中的結果,便於之後的重用。
正則表達式
//使用下面的方法 減小開銷
算法
3、避免頻繁的IO操做
應減小對cookie或localstorage的操做,由於對它們進行操做的API是同步的,而它們是多個tab頁面間共享的。
多頁面同時操做cookie和localstorage時,會存在同步加鎖機制。
4、避免頻繁的DOM操做
JavaScript訪問DOM元素緩慢,應作到:
①緩存已經查詢過的元素;
②線下更新完節點以後,在將它們添加到文檔樹中;
③避免使用JavaScript來修改頁面佈局。
5、使用微類庫
儘可能避免使用大而全的類庫,而是按需使用微類庫來輔助開發。
chrome