如何加快網(wǎng)站的打開速度?【廣州網(wǎng)站建設(shè)】
關(guān)于受歡迎網(wǎng)站用戶體驗的方法論有很多,最基本的:別讓我等!!提高網(wǎng)頁打開速度。為什么迅雷在下載軟件中獨(dú)樹一幟?為什么越來越多的用戶在低畫質(zhì)的視頻網(wǎng)站上在線觀看連續(xù)劇,而不是下載更清晰的視頻文件?答案是:用戶的耐心非常有限,用戶對速度的追求遠(yuǎn)遠(yuǎn)超過了對畫質(zhì)等因素的追求。
回到網(wǎng)站運(yùn)營問題上,你是否有在全國各地都測試過,訪問打開你的網(wǎng)站需要幾秒?
曾有很多研究表明:用戶最滿意的打開網(wǎng)頁時間是2-5秒,如果等待超過10秒,99%的用戶會關(guān)閉這個網(wǎng)頁。也許這樣講,各位還不會有太多感觸,接下來,我列舉一組數(shù)據(jù):Google網(wǎng)站訪問速度每慢400ms就導(dǎo)致用戶搜索請求下降0.59%;Amazon每增加100ms網(wǎng)站延遲將導(dǎo)致收入下降1%;雅虎如果有400ms延遲會導(dǎo)致流量下降5-9%。
怎么樣?現(xiàn)在感受如何?是不是該馬上去做測試工作呢。
這時候你也許會問:什么原因會導(dǎo)致網(wǎng)站打開慢?有什么辦法解決呢?別急,我一一道來。以下內(nèi)容有些偏技術(shù)層面,各位需要耐心閱讀。
1、減少HTTP請求數(shù)
用戶在打開一個網(wǎng)頁的時候,后臺程序響應(yīng)用戶所需的時間并不多,用戶等待的時間主要花費(fèi)在下載網(wǎng)頁元素上了,即HTML、CSS、JavaScript、Flash、圖片等,統(tǒng)計顯示,每增加一個元素,網(wǎng)頁載入的時間就增加25-40毫秒(取決于用戶的帶寬情況)。
所以,想要提高網(wǎng)頁打開速度,就要減少HTTP請求數(shù),方法有3種:
1)減少不必要的HTTP請求,例如用CSS圓角代替圓角圖片,減少圖片的使用。
2)合并文件,對于文本文件,可以直接合并內(nèi)容。例如將多個JS(JavaScript的簡稱)文件合并成一個,將多個CSS文件合并成一個。
3)優(yōu)化緩存,對于沒有變化的網(wǎng)頁元素(如頁頭、頁尾等),用戶再次訪問的時候沒有必要重新下載,直接從瀏覽器緩存里讀取就可以了。
2、使用CDN(Content Delivery Network,內(nèi)容分發(fā)網(wǎng)絡(luò))
CDN由一系列分散到各個不同地理位置上的Web服務(wù)器組成,它根據(jù)和用戶在網(wǎng)絡(luò)上的靠近程度來指定某臺服務(wù)器響應(yīng)用戶的請求。當(dāng)你的網(wǎng)站圖片很多事,就一樣要使用CDN了,比如現(xiàn)在的電商網(wǎng)站,幾乎都在使用CDN。
3、壓縮網(wǎng)頁元素
網(wǎng)頁中的每個元素越小,下載所需的時間就越少,這個很好理解?,F(xiàn)在比較成熟和流程的壓縮網(wǎng)頁的方式,是通過Gzip,我自己的實操經(jīng)驗來看,一般可以將網(wǎng)頁文本內(nèi)容減少70%以上。
4、樣式表放在網(wǎng)頁Head部分
這也是我實際操作過的案例,把樣式表(CSS文件)移到網(wǎng)頁的Head部分,可以提高頁面的加載速度,讓頁面元素順序顯示。
5、把JS文件放到網(wǎng)頁底部
網(wǎng)頁打開時,所有元素是順序顯示的。由于JS文件的特殊性,其相比其他元素來說,會加載的很慢,在JS文件下載完成之前,其他后面元素的順序顯示將被阻塞,因此把JS文件盡量放在底部,意味著內(nèi)容能被快速顯示。
6、把樣式表和JS腳本放到外部文件中
盡管將樣式表和JS腳本直接寫入網(wǎng)頁HTML中,可以減少外部文件調(diào)用數(shù)量,但是,這樣做會增加網(wǎng)頁的文件大小。綜合來看,將樣式表和JS腳本放到外部文件中,也許用戶首次訪問時會有點(diǎn)慢,但是后續(xù)在訪問網(wǎng)站時,用戶直接通過瀏覽器緩存就可以用,從而達(dá)到減少HTTP請求數(shù)的目的,為最優(yōu)的做法。
寫在最后的話:
在提升網(wǎng)頁打開速度經(jīng)常被忽視的一個問題是響應(yīng)。對于用戶來說,每次的操作,不管返回結(jié)果是慢,還是快,都要及時予以響應(yīng),最典型的例子就是:當(dāng)用戶點(diǎn)擊打開一張圖片時,是否有百分比數(shù)字顯示的進(jìn)度條,就是一個典型的響應(yīng)設(shè)計。
+相關(guān)資訊