加快網頁打開的速度,有三個途徑, (一)是提高網路頻寬,(二)是使用者在本機做優化,(三)是網站設計者對網頁做一定的優化。本文站在一個網站設計者的角度,分享一些優化網頁載入速度的小技巧。
一、優化圖片 幾乎沒有哪個網頁上是沒有圖片的。如果您經歷過56K數據機的年代,您一定不會很喜歡有大量圖片的網站。因為載入那樣一個網頁會花費大量的時間。即使在現在光世代網路頻寬有了很多的提高,56K數據機已淡出,優化圖片以加快網頁速度還是很有必要的。 優化圖片包括減少圖片數、降低圖像品質、使用恰當的格式。
- 減少圖片數:去除不必要的圖片。
- 降低圖像品質:如果不是很必要,嘗試降低圖像的品質,尤其是jpg格式,降低5%的品質看起來變化不是很大,但檔大小的變化是比較大的。
- 使用恰當的格式:請參閱下一點。
因此,在上傳圖片之前,您需要對圖片進行編輯,如果您覺得photoshop太麻煩,可以試試一些線上圖片編輯工具。懶得編輯而又想圖片有特殊的效果?可以試試用過調用javascript來實現圖片特效。
二、圖像格式的選擇 一般在網頁上使用的圖片格式有三種,jpg、png、gif。三種格式的具體技術指標不是這篇文章探討的內容,我們只需要知道在什麼時候應該使用什麼格式,以減少網頁的載入時間。
- JPG:一般用於展示風景、人物、藝術照的攝影作品。有時也用在電腦截屏上。
- GIF:提供的顏色較少,可用在一些對顏色要求不高的地方,比如網站logo、按鈕、表情等等。當然,gif的一個重要的應用是動畫圖片。就像用Lunapic製作的倒映圖片。
- PNG:PNG格式能提供透明背景,是一種專為網頁展示而發明的圖片格式。一般用於需要背景透明顯示或對圖像品質要求較高的網頁上。
三、優化CSS(Cascading Style Sheets)語法 CSS疊層樣式表讓網頁載入起來更高效,瀏覽體驗也得到提高。有了CSS,表格佈局的方式可以退休了。 但有時我們在寫CSS的時候會使用了一些比較囉嗦的語句,比如這句: margin-top: 10px; margin-right: 20px; margin-bottom: 10px; margin-left: 20px; 您可以將它簡化為: margin: 10px 20px 10px 20px; 又或者這句: <p class="decorated">A paragraph of decorated text</p> <p class="decorated">Second paragraph</p> <p class="decorated">Third paragraph</p> <p class="decorated">Forth paragraph</p> 可以用div來包含: <div class="decorated"> <p>A paragraph of decorated text</p> <p>Second paragraph</p> <p>Third paragraph</p> <p>Forth paragraph</p> </div> 簡化CSS能去除冗餘的屬性,提高運行效率。如果您寫好CSS後懶得去做簡化,您可以使用一些線上的簡化CSS工具,比如CleanCSS。
四、網址後加斜杠 有些網址,比如「www.wedo.com.tw/case 」,當伺服器收到這樣一個位址請求的時候,它需要花費時間去確定這個位址的檔案類型。如果220是一個目錄,不妨在網址後多加一個斜杠,讓其變成「www.wedo.com.tw/case/」,這樣伺服器就能一目了然地知道要訪問該目錄下的index或default檔,從而節省了載入時間。
五、標明高度和寬度 這點很重要,但很多人由於懶惰或其它原因總是將其忽視。當您在網頁上添加圖片或表格時,您應該指定它們的高度和寬度,也就是height和width參數。如果瀏覽器沒有找到這兩個參數,它需要一邊下載圖片一邊計算大小,如果圖片很多,瀏覽器需要不斷地調整頁面,這不但影響速度也影響瀏覽體驗。下面是一個比較友好的圖片代碼: <img src="/images/article-1.jpg" alt="相關文章彙整" width="146" height="105"/> 當瀏覽器知道了高度和寬度參數後,即使圖片暫時無法顯示,頁面上也會騰出圖片的空位,然後繼續載入後面的內容。從而載入時間快了,瀏覽體驗也更好了。
六、減少http請求 當瀏覽者打開某個網頁,瀏覽器會發出很多物件請求(圖像、腳本等等),視乎網路延時情況,每個物件載入都會有所延遲。如果網頁上物件很多,這可以需要花費大量的時間。因此要為http請求減少負擔,如何減少負擔?
- 去除一些不必要的物件。
- 將臨近的兩張圖片合成一張。
- 合併CSS檔案。
看看下面這段代碼,需要載入三個CSS: <link rel="stylesheet" type="text/css" href="/body.css" _fcksavedurl=""/body.css"" _fcksavedurl=""/body.css"" /> <link rel="stylesheet" type="text/css" href="/side.css" /> <link rel="stylesheet" type="text/css" href="/footer.css" /> 我們可以將其合成一個: <link rel="stylesheet" type="text/css" href="/style.css" /> 從而減少http請求。
七、其它小技巧
- 去除不必要載入項。
- 如果在網頁上嵌入了其它網站的widget,如果有選擇餘地,一定要選擇速度快的。
- 儘量用圖片代替flash,這對SEO搜尋也有好處。
- 有些內容可以靜態化就將其靜態化,以減少伺服器的負擔,這對SEO搜尋也有好處。
- 統計代碼放在頁尾。
(此篇文章為網路轉載,如有冒犯,請來信告知,當即刻移除!)
|