這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)幫你提高網(wǎng)站訪問(wèn)速度縮短網(wǎng)頁(yè)加載時(shí)間的方法有哪些,文章內(nèi)容豐富且以專(zhuān)業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
我們提供的服務(wù)有:成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、珠山ssl等。為上1000家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢(xún)和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的珠山網(wǎng)站制作公司
網(wǎng)友上網(wǎng)都不喜歡用太多的時(shí)間等待網(wǎng)頁(yè)的打開(kāi),等待的越長(zhǎng),用戶(hù)可能會(huì)直接關(guān)閉網(wǎng)頁(yè),這樣就會(huì)損失很多流量!其次,關(guān)鍵字的排名與網(wǎng)頁(yè)的打開(kāi)速度也有關(guān)系,這個(gè)主要體現(xiàn)搜索引擎對(duì)用戶(hù)體驗(yàn)度上,用戶(hù)體驗(yàn)度好,排名相對(duì)其它網(wǎng)站就好些。因此我覺(jué)得我們有必要去提高網(wǎng)頁(yè)的打開(kāi)速度,這個(gè)不需要太多的成本投入,只需要平時(shí)多注意一些小技巧就行了!下面給出20種方法幫你提高網(wǎng)站訪問(wèn)速度縮短網(wǎng)頁(yè)加載時(shí)間。
1、減少頁(yè)面HTTP請(qǐng)求數(shù)量
比較直接的理解就是要減少調(diào)用其他頁(yè)面、文件的數(shù)量。
A.我們?cè)谑褂胏ss格式控制的時(shí)候,經(jīng)常會(huì)采用background載入很多圖形文件,每個(gè)background的圖像至少產(chǎn)生1次HTTP請(qǐng)求,一般我們?yōu)榱俗岉?yè)面生動(dòng)活潑會(huì)大量使用background來(lái)加載背景圖,要改善這個(gè)狀況,可以采用css的1個(gè)有用的background-position屬性來(lái)加載背景圖,我們將需要頻繁加載的多個(gè)圖片合成為1個(gè)單獨(dú)的圖片,需要加載時(shí),采用以下形式加載即可將這部分圖片加載的HTTP請(qǐng)求縮減為1個(gè)。
background:url(....) no-repeat x-offset y-offset;
B.采用Image maps,這個(gè)方法也比較常用,只是限于同1個(gè)區(qū)域使用。
C.Inline images,這個(gè)方法很少見(jiàn)到,但對(duì)于很小很簡(jiǎn)單的圖像卻是很實(shí)用的,相關(guān)語(yǔ)法標(biāo)準(zhǔn)參照:tools.ietf.org/html/rfc2397。
2、使用cdn(Content Delivery Network)網(wǎng)絡(luò)加速
現(xiàn)在國(guó)內(nèi)做CDN加速業(yè)務(wù)的公司很多,簡(jiǎn)單講,就是將你的圖片、視頻擴(kuò)散到CDN網(wǎng)絡(luò)所能到達(dá)之處,讓用戶(hù)訪問(wèn)時(shí)能就近下載到這些文件,從而達(dá)到網(wǎng)絡(luò)提速的目的,這樣做,同時(shí)能減輕你自己網(wǎng)站的負(fù)載。
3、添加文件過(guò)期或緩存頭
對(duì)于同一用戶(hù)頻繁訪問(wèn)的圖片、Js腳本文件等可以在Apache或Nginx設(shè)置其緩沖 時(shí)間,例如設(shè)置24小時(shí)過(guò)期時(shí)間,這樣用戶(hù)在訪問(wèn)過(guò)該頁(yè)面之后再次訪問(wèn)時(shí),同一組圖片或JS不會(huì)再重復(fù)下載,從而減少了HTTP請(qǐng)求,用戶(hù)訪問(wèn)速度明顯有 所提升,同時(shí)服務(wù)器負(fù)載也會(huì)下降。下面給出nginx配置中緩存控制的例子:
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { expires 30d;#設(shè)置30天過(guò)期 } location ~ .*\.(js|css)?$ { expires 1h;#設(shè)置1小時(shí)過(guò)期 }
4、服務(wù)器開(kāi)啟gzip壓縮
這個(gè)大家都比較了解,即將需要傳輸?shù)膬?nèi)容壓縮后傳輸?shù)娇蛻?hù)端再解壓,這樣在網(wǎng)絡(luò)上傳輸?shù)?數(shù)據(jù)量會(huì)大幅減小。通常在服務(wù)器上的Apache、Nginx可以直接開(kāi)啟這個(gè)設(shè)置,也可以從代碼角度直接設(shè)置傳輸文件頭,增加gzip的設(shè)置,也可以從 負(fù)載均衡設(shè)備直接設(shè)置。不過(guò)需要留意的是,這個(gè)設(shè)置會(huì)略微增加服務(wù)器的負(fù)擔(dān)。
5、css格式定義放置在文件頭部
這項(xiàng)設(shè)置對(duì)于用戶(hù)端是慢速網(wǎng)絡(luò)或網(wǎng)頁(yè)內(nèi)容比較龐大的情況比較有利,可以在網(wǎng)頁(yè)逐步呈現(xiàn)的同時(shí)仍會(huì)保持格式信息,不影響網(wǎng)頁(yè)美感。
6、Javascript腳本放在文件末尾
很多Javascript腳本執(zhí)行效率低下,或者有的第3方域名腳本出現(xiàn)意外無(wú)法載入, 如果將這些腳本放置到頁(yè)面比較靠前的位置,可能會(huì)導(dǎo)致我們自己網(wǎng)站的內(nèi)容載入速度下降甚至無(wú)法正常加載,所以一般將這些腳本放置在網(wǎng)頁(yè)文件末尾,一定要放 置在前面的腳本要改用所謂的“后載入”方式加載,在主體網(wǎng)頁(yè)加載完成后再加載,防止其影響到主體網(wǎng)頁(yè)的加載速度。
7、避免使用CSS腳本(CSS Expressions)
有時(shí)為了要css的參數(shù)動(dòng)態(tài)改變,可能會(huì)采用css expression來(lái)實(shí)現(xiàn),但這樣做得不償失,會(huì)使用戶(hù)端瀏覽器負(fù)擔(dān)明顯加重,所以不建議這樣做,如果需要改變,可以使用Javascript腳本去實(shí)現(xiàn)。
8、css、javascript改由外部調(diào)用
如果css、js內(nèi)容比較龐大,盡量不要寫(xiě)到同1個(gè)頁(yè)面中去,改由外部載入比較妥當(dāng),因?yàn)闉g覽器本身會(huì)對(duì)css、js文件進(jìn)行緩存。
9、壓縮Javascript、CSS代碼
一般js、css文件中存在大量的空格、換行、注釋?zhuān)@些利于閱讀,如果能夠壓縮掉,將會(huì)很有利于網(wǎng)絡(luò)傳輸。這方面的工具也有很多,一般可以保留開(kāi)發(fā)版本,利用工具生成生產(chǎn)版本,2個(gè)文件比較,一般壓縮率能達(dá)到50%以上,減少的數(shù)據(jù)量還是比較可觀的。
我這個(gè)博客剛改版完成,各種代碼還沒(méi)有進(jìn)行優(yōu)化和壓縮,目前yslow評(píng)級(jí)只能達(dá)到D,等有時(shí)間進(jìn)行部分優(yōu)化,達(dá)到C等級(jí)應(yīng)該問(wèn)題不大。
10、避免采用301、302轉(zhuǎn)向
11、養(yǎng)成良好的開(kāi)發(fā)維護(hù)習(xí)慣,盡量避免腳本重復(fù)調(diào)用
12、配置ETags
13、Ajax采用緩存調(diào)用
這個(gè)的使用可以參照Discuz論壇代碼,里面對(duì)于大量使用的Ajax調(diào)用都采用了緩存 調(diào)用方式,一般采用附加特征參數(shù)方式實(shí)現(xiàn),注意其中的