一般來(lái)說(shuō),訪(fǎng)客都不喜歡用太多的時(shí)間去等待網(wǎng)頁(yè)的打開(kāi),等待的越長(cháng),用戶(hù)直接關(guān)閉網(wǎng)頁(yè)的可能性就越大,這樣就會(huì )損失很多流量!其次,關(guān)鍵字排名與網(wǎng)頁(yè)的打開(kāi)速度也有關(guān)系,這個(gè)主要體現搜索引擎對用戶(hù)體驗度上,用戶(hù)體驗度好,排名相對其它網(wǎng)站就好些。
因此覺(jué)得各位站長(cháng)有必要去提高網(wǎng)頁(yè)的打開(kāi)速度,這個(gè)不需要太多的成本投入,只需要平時(shí)多注意一些小技巧就行了,下面就為大家分享20種方法幫你提高網(wǎng)站訪(fǎng)問(wèn)速度,縮短網(wǎng)頁(yè)加載時(shí)間。
1、減少頁(yè)面HTTP請求數量
比較直接的理解就是要減少調用其他頁(yè)面、文件的數量。
(1)、我們在使用css格式控制的時(shí)候,經(jīng)常會(huì )采用background載入很多圖形文件,每個(gè)background的圖像至少產(chǎn)生1次HTTP請求,一般我們?yōu)榱俗岉?yè)面生動(dòng)活潑會(huì )大量使用background來(lái)加載背景圖,要改善這個(gè)狀況,可以采用css的1個(gè)有用的background-position屬性來(lái)加載背景圖,建議將需要頻繁加載的多個(gè)圖片合成為1個(gè)單獨的圖片,需要加載時(shí),采用以下形式加載即可將這部分圖片加載的HTTP請求縮減為1個(gè):
(2)、采用Image maps,這個(gè)方法也比較常用,只是限于同1個(gè)區域使用。
(3)、Inline images,這個(gè)方法很少見(jiàn)到,但對于很小很簡(jiǎn)單的圖像卻是很實(shí)用的。
2、添加文件過(guò)期或緩存頭
對于同一用戶(hù)頻繁訪(fǎng)問(wèn)的圖片、Js腳本文件等可以在A(yíng)pache或Nginx設置其緩沖時(shí)間,例如設置24小時(shí)過(guò)期時(shí)間,這樣用戶(hù)在訪(fǎng)問(wèn)過(guò)該頁(yè)面之后再次訪(fǎng)問(wèn)時(shí),同一組圖片或JS不會(huì )再重復下載,從而減少了HTTP請求,用戶(hù)訪(fǎng)問(wèn)速度明顯有所提升,同時(shí)服務(wù)器負載也會(huì )下降。
下面給出nginx配置中緩存控制的例子:
3、服務(wù)器開(kāi)啟gzip壓縮
這個(gè)大家都比較了解,即將需要傳輸的內容壓縮后傳輸到客戶(hù)端再解壓,這樣在網(wǎng)絡(luò )上傳輸的數據量會(huì )大幅減小。
通常在服務(wù)器上的Apache、Nginx可以直接開(kāi)啟這個(gè)設置,也可以從代碼角度直接設置傳輸文件頭,增加gzip的設置,也可以從 負載均衡設備直接設置,不過(guò)需要留意的是,這個(gè)設置會(huì )略微增加服務(wù)器的負擔。
4、css格式定義放置在文件頭部
這項設置對于用戶(hù)端是慢速網(wǎng)絡(luò )或網(wǎng)頁(yè)內容比較龐大的情況比較有利,可以在網(wǎng)頁(yè)逐步呈現的同時(shí)仍會(huì )保持格式信息,不影響網(wǎng)頁(yè)美感。
5、Javascript腳本放在文件末尾
很多Javascript腳本執行效率低下,或者有的第3方域名腳本出現意外無(wú)法載入,如果將這些腳本放置到頁(yè)面比較靠前的位置,可能會(huì )導致我們自己網(wǎng)站的內容載入速度下降甚至無(wú)法正常加載,所以,一般將這些腳本放置在網(wǎng)頁(yè)文件末尾,一定要放置在前面的腳本要改用所謂的 后載入 方式加載,在主體網(wǎng)頁(yè)加載完成后再加載,防止其影響到主體網(wǎng)頁(yè)的加載速度。
6、避免使用CSS腳本(CSS Expressions)
有時(shí)為了要css的參數動(dòng)態(tài)改變,可能會(huì )采用css expression來(lái)實(shí)現,但這樣做得不償失,會(huì )使用戶(hù)端瀏覽器負擔明顯加重,所以,不建議這樣做,如果需要改變,可以使用Javascript腳本去實(shí)現。
7、css、javascript改由外部調用
如果css、js內容比較龐大,盡量不要寫(xiě)到同1個(gè)頁(yè)面中去,改由外部載入比較妥當,因為瀏覽器本身會(huì )對css、js文件進(jìn)行緩存。
8、使用多域名負載網(wǎng)頁(yè)內的多個(gè)文件、圖片
記得有資料說(shuō)明,IE在網(wǎng)頁(yè)載入過(guò)程中,在同1時(shí)刻,對同1域名并行加的HTTP請求數量最高為2個(gè),如果網(wǎng)頁(yè)需要加載的文件數量超過(guò)2個(gè)(通常遠遠超過(guò)),要加快網(wǎng)頁(yè)訪(fǎng)問(wèn)速度,最好將文件分布到多個(gè)域名,例如19樓,其js文件采用獨立的域名,據說(shuō)百度的圖片服務(wù)器數量在20臺以上。
9、縮減iframe的使用,如無(wú)必要,盡量不要使用
iframe通常用于不同域名內容的加載,這同時(shí)也可能因iframe內容加載速度影響到主網(wǎng)頁(yè)加載速度,如果可能,把需要加載的內容抓取到本地直接嵌入。如果實(shí)在需要iframe加載,采用后載入方式實(shí)現。
10、壓縮Javascript、CSS代碼
一般js、css文件中存在大量的空格、換行、注釋?zhuān)@些利于閱讀,如果能夠壓縮掉,將會(huì )很有利于網(wǎng)絡(luò )傳輸,這方面的工具也有很多,一般可以保留開(kāi)發(fā)版本,利用工具生成生產(chǎn)版本,2個(gè)文件比較,一般壓縮率能達到50%以上,減少的數據量還是比較可觀(guān)的,具體的工具軟件可使用。
我這個(gè)博客剛改版完成,各種代碼還沒(méi)有進(jìn)行優(yōu)化和壓縮,目前yslow評級只能達到D,等有時(shí)間進(jìn)行部分優(yōu)化,達到C等級應該問(wèn)題不大。
11、避免腳本重復調用
養成良好的開(kāi)發(fā)維護習慣,盡量避免腳本重復調用,因為過(guò)多的腳本重復調用不但會(huì )使網(wǎng)頁(yè)代碼顯得很臃腫,也會(huì )因為腳本文件太多拖延網(wǎng)頁(yè)的打開(kāi)速度。
12、優(yōu)化圖片文件
優(yōu)化圖片文件,減小其尺寸,特別是縮略圖,一定要按尺寸生成縮略圖然后調用,不要在網(wǎng)頁(yè)中用resize方法實(shí)現,雖然這樣看到的圖片外形笑了,但是其加載的數據量一點(diǎn)也沒(méi)減少。曾經(jīng)見(jiàn)過(guò)有人在網(wǎng)頁(yè)中加載的縮略圖,其真實(shí)尺寸有10M之巨。
普通圖像、icon也要盡可能壓縮后,可以采用web圖像保存、減少顏色數等等方法實(shí)現。
13、配置ETags
ETag全稱(chēng)為Entity Tag,意思是實(shí)體標簽,從名字上看,是對于某種實(shí)體的一個(gè)標識,它屬于HTTP協(xié)議的一部分,也就是所有的Web服務(wù)器都應該(也確實(shí)能)支持這個(gè)特性。
它的作用是用一個(gè)特殊的字符串來(lái)標識某個(gè)資源的 版本 ,客戶(hù)端(瀏覽器)來(lái)請求的時(shí)候,可以比較,如果ETag一致,則表示該資源并沒(méi)有修改過(guò),客戶(hù)端(瀏覽器)可以使用自己緩存的版本。
14、Ajax采用緩存調用
這個(gè)的使用可以參照Discuz論壇代碼,里面對于大量使用的Ajax調用都采用了緩存 調用方式,一般采用附加特征參數方式實(shí)現。
不過(guò),要提醒大家注意其中的特征參數(如下圖所示),這個(gè)參數不變化就使用緩存文件,如果發(fā)生變化則重新下載新文件或更新信息。
15、合理使用Flush
用戶(hù)端發(fā)送瀏覽請求后,服務(wù)器端一般要花銷(xiāo)200-500ms去處理這些請求,在此期間,用戶(hù)端瀏覽器處于等待狀態(tài),如果要減少用戶(hù)等待時(shí)間,可以在適當的位置使用flush,將已經(jīng)就緒的內容推送到用戶(hù)端,這在php中很容易實(shí)現例如:
16、Ajax調用盡量采用GET方法調用
實(shí)際使用XMLHttpRequest時(shí),如果使用POST方法實(shí)現,會(huì )發(fā)生2次HTTP請求,而使用GET方法只會(huì )發(fā)生1次HTTP請求。如果改用GET方法,HTTP請求減少50%!
17、盡可能減少DCOM元素
這個(gè)很好理解,就是盡可能減少網(wǎng)頁(yè)中各種 元素數量,這種的冗余很?chē)乐?,而我們完全可以用取代之?/p>
18、避免采用302轉向
301是永久性跳轉,302是臨時(shí)性跳轉,一般情況下都是301跳轉,很少人用302的,301跳轉是讓從一個(gè)網(wǎng)站轉移到另一個(gè)網(wǎng)站上,302跳轉的還是在原來(lái)的網(wǎng)站上,只用于臨時(shí)的跳轉,當然,一般使用這些跳轉的,都需要一定的時(shí)間來(lái)緩沖,如果302跳轉用的時(shí)間過(guò)長(cháng),可能會(huì )被百度判斷為作弊,會(huì )被k站。
19、采用分頁(yè)的方式展現
當頁(yè)面內容龐大到一定程度,可以采用分頁(yè)的方式展現,或者taobao的那種翻頁(yè)后載入方式,這樣可以最大程度的減少單頁(yè)面的打開(kāi)速度,提高頁(yè)面的打開(kāi)速度。
20、使用CDN(Content Delivery Network)網(wǎng)絡(luò )加速
現在國內做CDN加速業(yè)務(wù)的公司很多,簡(jiǎn)單講,就是將你的圖片、視頻擴散到CDN網(wǎng)絡(luò )所能到達之處,讓用戶(hù)訪(fǎng)問(wèn)時(shí)能就近下載到這些文件,從而達到網(wǎng)絡(luò )提速的目的,這樣做,同時(shí)能減輕你自己網(wǎng)站的負載。