歡迎您來到煙臺(tái)紅旗網(wǎng)絡(luò)科技有限公司!
網(wǎng)站的訪問速度慢,就會(huì)影響響應(yīng)速度、蜘蛛爬行速度,以及用戶體驗(yàn)度,從而導(dǎo)致網(wǎng)站的流量流失,排名下降,下面煙臺(tái)網(wǎng)站建設(shè)就多年經(jīng)驗(yàn)為您介紹如何提高網(wǎng)站煩人訪問速度。
一、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è)的加載速度。
二、使用多域名負(fù)載網(wǎng)頁(yè)內(nèi)的多個(gè)文件、圖片。有資料說明,IE在網(wǎng)頁(yè)載入過程中,在同1時(shí)刻,對(duì)同1域名并行加的HTTP請(qǐng)求數(shù)量高為2個(gè),如果網(wǎng)頁(yè)需要加載的文件數(shù)量超過2個(gè)(通常遠(yuǎn)遠(yuǎn)超過..),要加快網(wǎng)頁(yè)訪問速度,盡量將文件分布到多個(gè)域名,js文件采用獨(dú)立的域名,據(jù)說百度的圖片服務(wù)器數(shù)量在20臺(tái)以上。
三、服務(wù)器開啟gzip壓縮。就是將需要傳輸?shù)膬?nèi)容壓縮后傳輸?shù)娇蛻舳嗽俳鈮?,這樣在網(wǎng)絡(luò)上傳輸?shù)臄?shù)據(jù)量會(huì)大幅減小。通常在服務(wù)器上的Apache、Nginx可以直接開啟這個(gè)設(shè)置,也可以從代碼角度直接設(shè)置傳輸文件頭,增加gzip的設(shè)置,也可以從負(fù)載均衡設(shè)備直接設(shè)置。不過需要留意的是,這個(gè)設(shè)置會(huì)略微增加服務(wù)器的負(fù)擔(dān)。
四、使用CDN(ContentDeliveryNetwork)網(wǎng)絡(luò)加速?,F(xiàn)在國(guó)內(nèi)做CDN加速業(yè)務(wù)的公司很多,簡(jiǎn)單講,就是將圖片、視頻擴(kuò)散到CDN網(wǎng)絡(luò)所能到達(dá)之處,讓用戶訪問時(shí)能就近下載到這些文件,從而達(dá)到網(wǎng)絡(luò)提速的目的,這樣做,同時(shí)能減輕你自己網(wǎng)站的負(fù)載。
五、合理使用Flush。用戶端發(fā)送瀏覽請(qǐng)求后,服務(wù)器端一般要花銷200-500ms去處理這些請(qǐng)求,在此期間,用戶端瀏覽器處于等待狀態(tài),如果要減少用戶等待時(shí)間,可以在適當(dāng)?shù)奈恢檬褂胒lush,將已經(jīng)就緒的內(nèi)容推送到用戶端,這在php中很容易實(shí)現(xiàn)。
六、避免使用CSS腳本(CSSExpressions)。有時(shí)為了要css的參數(shù)動(dòng)態(tài)改變,可能會(huì)采用cssexpression來實(shí)現(xiàn),但這樣做得不償失,會(huì)使用戶端瀏覽器負(fù)擔(dān)明顯加重,所以不建議這樣做,如果需要改變,可以使用Javascript腳本去實(shí)現(xiàn)。
七、css、javascript改由外部調(diào)用。如果css、js內(nèi)容比較龐大,盡量不要寫到同1個(gè)頁(yè)面中去,改由外部載入比較妥當(dāng),因?yàn)闉g覽器本身會(huì)對(duì)css、js文件進(jìn)行緩存。
八、css格式定義放置在文件頭部。
這項(xiàng)設(shè)置對(duì)于用戶端是慢速網(wǎng)絡(luò)或網(wǎng)頁(yè)內(nèi)容比較龐大的情況比較有利,可以在網(wǎng)頁(yè)逐步呈現(xiàn)的同時(shí)仍會(huì)保持格式信息,不影響網(wǎng)頁(yè)美感。
九、避免采用301、302轉(zhuǎn)向。
十、配置ETags。
十一、養(yǎng)成良好的開發(fā)維護(hù)習(xí)慣,盡量避免腳本重復(fù)調(diào)用。
十二、盡可能減少DCOM元素。這個(gè)很好理解,就是盡可能減少網(wǎng)頁(yè)中各種<>元素?cái)?shù)量。
十三、當(dāng)頁(yè)面內(nèi)容龐大到一定程度,可以采用分頁(yè)的方式展現(xiàn),或者某寶的那種翻頁(yè)后載入方式。
十四、Ajax調(diào)用盡量采用GET方法調(diào)用。實(shí)際使用XMLHttpRequest時(shí),如果使用POST方法實(shí)現(xiàn),會(huì)發(fā)生2次HTTP請(qǐng)求,而使用GET方法只會(huì)發(fā)生1次HTTP請(qǐng)求。如果改用GET方法,HTTP請(qǐng)求減少50%!
十五、Ajax采用緩存調(diào)用。這個(gè)使用可以參照Discuz論壇代碼,里面對(duì)于大量使用的Ajax調(diào)用都采用了緩存調(diào)用方式,一般采用附加特征參數(shù)方式實(shí)現(xiàn),注意其中的特征參數(shù),這個(gè)參數(shù)不變化就使用緩存文件,如果發(fā)生變化則重新下載新文件或更新信息。
十六、縮減iframe的使用,如無(wú)必要,盡量不要使用。iframe通常用于不同域名內(nèi)容的加載,這同時(shí)也可能因iframe內(nèi)容加載速度影響到主網(wǎng)頁(yè)加載速度,如果可能,把需要加載的內(nèi)容抓取到本地直接嵌入。如果實(shí)在需要iframe加載,采用后載入方式實(shí)現(xiàn)。
十七、優(yōu)化圖片文件。優(yōu)化圖片文件,減小其尺寸,特別是縮略圖,一定要按尺寸生成縮略圖然后調(diào)用,不要在網(wǎng)頁(yè)中用resize方法實(shí)現(xiàn),其實(shí)這樣加載的數(shù)據(jù)量一點(diǎn)也沒減少。普通圖像、icon也要盡可能壓縮后,可以采用web圖像保存、減少顏色數(shù)等等方法實(shí)現(xiàn)。
十八、壓縮Javascript、CSS代碼。一般js、css文件中存在大量的空格、換行、注釋,這些利于閱讀,如果能夠壓縮掉,將會(huì)很有利于網(wǎng)絡(luò)傳輸。這方面的工具也有很多,一般可以保留開發(fā)版本,利用工具生成生產(chǎn)版本,2個(gè)文件比較,一般壓縮率能達(dá)到50%以上,減少的數(shù)據(jù)量還是比較可觀的。
十九、減少頁(yè)面HTTP請(qǐng)求數(shù)量。比較直接的理解就是要減少調(diào)用其他頁(yè)面、文件的數(shù)量。
1、我們?cè)谑褂胏ss格式控制的時(shí)候,經(jīng)常會(huì)采用background載入很多圖形文件,每個(gè)background的圖像至少產(chǎn)生1次HTTP請(qǐng)求,一般我們?yōu)榱俗岉?yè)面生動(dòng)活潑會(huì)大量使用background來加載背景圖,要改善這個(gè)狀況,可以采用css的1個(gè)有用的background-position屬性來加載背景圖,我們將需要頻繁加載的多個(gè)圖片合成為1個(gè)單獨(dú)的圖片,需要加載時(shí),采用以下形式加載即可將這部分圖片加載的HTTP請(qǐng)求縮減為1個(gè)。
2、采用Imagemaps,這個(gè)方法也比較常用,只是限于同1個(gè)區(qū)域使用。
3、Inlineimages,這個(gè)方法很少見到,但對(duì)于很小很簡(jiǎn)單的圖像卻是很實(shí)用的,相關(guān)語(yǔ)法標(biāo)準(zhǔn)參照:tools.ietf.org/html/rfc2397。
二十、添加文件過期或緩存頭。對(duì)于同一用戶頻繁訪問的圖片、Js腳本文件等可以在Apache或Nginx設(shè)置其緩沖時(shí)間,例如設(shè)置24小時(shí)過期時(shí)間,這樣用戶在訪問過該頁(yè)面之后再次訪問時(shí),同一組圖片或JS不會(huì)再重復(fù)下載,從而減少了HTTP請(qǐng)求,用戶訪問速度明顯有所提升,同時(shí)服務(wù)器負(fù)載也會(huì)下降。