當前位置:首頁 >  站長 >  搜索優(yōu)化 >  正文

SEO性能優(yōu)化之網站速度優(yōu)化

 2015-03-12 15:15  來源: 心情客棧   我來投稿 撤稿糾錯

  域名預訂/競價,好“米”不錯過

網站速度不僅影響用戶體驗,也影響Google robot對網站的爬取,進而影響網站收錄;所以網站速度對于SEO的重要性不可小覷。Google Page Speed 主要用于分析檢測頁面加載速度和元素,提出建議。技術人員從而可以依據Page Speed的要點來修正和提高網頁網站的質量。對于網頁需要改進的地方,PageSpeed不僅提供了優(yōu)化建議,甚至還直接把優(yōu)化的最終結果都給提供出來。

Page speed來自于Google,可以下載插件安裝在Firefox或Chrome上。插件一般都是英文版,Firefox也有中文版本,但缺乏詳細解釋。這里先把主要檢測事項的中英文對比出來。然后針對細致的項進行解釋并盡可能提供技術上操作說明。也可以用另一種方法,直接用Googlehttps://developers.google.com/speed/pagespeed/insights 網站性能檢測工具檢測網站需要優(yōu)化的細節(jié)。

今天我將介紹JavaScript和CSS優(yōu)化相關要點,所有的整理資料都是來自于falconhan。

一、壓縮JavaScript (Minify JavaScript)

壓縮JavaScript的方法跟壓縮HTML和壓縮CSS在本質上的好處是一樣的。一般的方式就是3種:壓縮多余的空格和換行符;刪除注釋;把較長的變量名稱和過程名稱統(tǒng)一替換為很短的名稱。

壓縮工具也有很多,之前提到的YUI Compressor就可以執(zhí)行。

Google/Gtmetrix有一句話看不懂,We recommend minifying any JS files that are 4096 bytes or larger in size. You should see a benefit for any file that can be reduced by 25 bytes or more。意思是盡可能壓縮4K意思的JS文件,所獲好處是文件可以被縮減25個字節(jié)或以上。猜測原因是緩存器的容量是4K,如果JS超過此大小將不會放入緩存中?

另外不確定的是,可被縮減的25bytes的文件是JS本身還是指其它文件,why? 高手請指示一二…………….

二、合并外部JavaScript (Combine external JavaScript)

合并外部的JavaScript文件,跟合并外部CSS是類似的原理,都能夠有效減少往返時間(RTT)及在下載其它資源時減少延遲。過多的JS和CSS文件會導致過度的HTTP開銷,簡單有效的處理方式就是將外部的JS文件簡化后再合并。

關于外部JavaScript的使用,有一些建議:

將頁面的JavaScript分割為2個文件,一個包含那些必須的代碼,這樣在頁面加載之初會率先調用。另一個就是可以等到其它HTML內容都加載完再調用的JS。在頁面的之前使用的JavaScript,盡可能將其簡化,這樣能避免加載和解析時間過長而阻止其它內容能快速展現。將那些極少被大多數頁面使用到的JavaScript代碼,放置在獨立的文件中,這樣可避免多數頁面不要調用它而浪費時間。對于那些不需要緩存的小段的JavaScript代碼,考慮將其放在HTML頁面代碼當中。JS在頁面中放置的位置也有講究的,重要的內容優(yōu)先展示是基本原則,還要考慮到JS或其它資源的并行下載以進一步節(jié)省時間。

三、內嵌小型 JavaScript (Inline small JavaScript)

內嵌小型JavaScript能夠節(jié)省JS請求所導致的服務器請求/響應時間開銷。就是對于小段的JS代碼,直接嵌入在頁面中會比單獨的外部調用會好一些。但是更理想的解決方法是將小段JS整合起來再進行外部調用,參見合并外部的JavaScript。從節(jié)省時間的角度來考慮,JavaScript代碼跟CSS用法類似,僅用于某個特效的小段代碼可以寫入在頁面里,用于多個地方的JS可以合并來外部調用。

四、優(yōu)化樣式表和腳本的排列順序 (Optimize the order of styles and scripts)

正確地部署外部樣式和不管內外的Scripts腳本,能夠合理并行下載資源,從而縮減瀏覽器對頁面進行渲染的時間。由于JavaScript能夠改變網頁的內容和樣式布局等,瀏覽器在遇到js時就會延遲執(zhí)行渲染任何內容,而讓位于先下載、解析和執(zhí)行Script腳本內容。然而,比請求的時間更重要的是,瀏覽器在碰到Script時,其它資源沒辦法并行下載處理,會導致頁面停頓,可能影響用戶體驗。

關于樣式表和腳本之間的順序關系,有幾個推薦的處理順序,一是盡可能把頁面的重要內容在腳本和樣式表前先加載,二是外部的腳本放在外部的樣式之后,三是把內部的腳本放在所以其它內容之后。

五、壓縮CSS (Minify CSS)

壓縮CSS和壓縮JS是一個道理,就是減少文件體積提高下載速度,瀏覽器在解析和執(zhí)行CSS的時候也能提高速度。一個可用的工具是 YUI Compressor。

CSS自己壓縮也可以,有一些方法,如使用CSS縮寫塊狀間隔,

” padding-top:5px

padding-right:6px

padding-bottom:7px

padding-left:8px”

可以縮寫為 padding:5px 6px 7px 8px;

每兩位的顏色值都一樣可簡寫,#aabb11 可寫為 #ab1

去掉沒必要的空格、換行、注釋,去掉沒必要的字體選項等。

六、去掉無用的CSS (Remove unused CSS)

PageSpeed告訴你,當前頁面里面有多少CSS樣式是沒有被用到的,去掉它們可以進一步加快瀏覽器對CSS的解析量,提供整個頁面的加載速度。

很多網站的做法都是大部分頁面會沿用統(tǒng)一的CSS文件,這樣在管理上比較容易些。但會導致了很多樣式并不會被頁面中的元素所使用,對單頁面來講造成一定的資源冗余。PageSpeed雖然把每個沒有被當前頁用到的CSS樣式都列出來,但覺得這個實際的指導意義不夠明顯,因為,為每個頁單獨配一個CSS文件顯得特二。

最好的處理辦法是盡可能把CSS進行分類管理,比如針對不同頻道頁的(模板可能不同),針對圖片形式的,針對表格的等,不同的頁面會調用到不同的CSS。如果在建站時就規(guī)劃好,這種方法就能兼顧CSS精簡和管理上的便利。還有一點需要注意,就是在”合并外部的CSS”這個優(yōu)化選項里提到的,多個較小的CSS應該合并到一個文件里以減少HTTP請求量,或者使用內聯樣式。

七、內嵌小型CSS (Inline small CSS)

將CSS代碼進行外部調用是有好處的(最主要是方便統(tǒng)一管理),但是不能盲目地把所有CSS都改為外部調用。把一些小型(片段或體積不大)的CSS代碼嵌入在頁面HTML里,讓瀏覽器直接下載解析,可以減少服務器請求/應答的時間開銷,從而加快頁面的加載速度。另外也可以把小型CSS都聚合為較大的單個CSS文件,再進行外部調用。

Google Pagespeed光說小型CSS,但到底體積大小是多少才算小。。。一說是768bytes,另外從某人試驗中(基于Apache)得出另一個結論:體積小于2K(2046 bytes)的CSS代碼算是小型,可以節(jié)省整體時間。以上2個說法都可作為參考,實際情況還需要進行測試,但小于768的就肯定適合去合并外調或內聯使用。

八、合并外部的CSS (Combine external CSS)

合并外部樣式表文件,能夠減少往返時間(RTT)及在下載其它資源時減少延遲。外部過多的JS和CSS文件會導致過度的HTTP開銷,簡單處理方式就是合并,最好不要超過3個CSS文件的調用。

關于CSS的使用上,有一些建議:

將CSS分割為2個文件,一個是包含必須的樣式,就是在頁面加載之初會影響視覺效果的。另一個就是可以等到其它HTML內容都加載完再調用的。

對于那些不常被大多數頁面用到的CSS樣式,考慮放入到單獨文件(比如有些表格樣式CSS,只針對某些頁面有效)。而對于那些只是對某個元素應用的CSS,則推薦使用內聯樣式。不要在CSS里使用 @import 來再調用其它的CSS,要么合并到主CSS里,要么單獨再外部調用一次。

九、使用高效的CSS選擇符 (Use efficient CSS selectors)

使用高效的CSS選擇符能夠加速頁面展現,盡可能避免使用那些能夠匹配很多元素的選擇符。當瀏覽器在解析HTML時,先把CSS樣式表中指定的元素,根據標準CSS重疊和順序規(guī)則,建造為所有元素展現的結構文檔樹。在火狐瀏覽器里(其它類似),樣式渲染器將為每個元素,按照從右到左的規(guī)則進行匹配(最右邊的選擇符叫做”Key”),為所有元素找到渲染的次序規(guī)則。

越少的CSS規(guī)則將會使用更少的時間。因此,對于CSS樣式來講,最好就先刪除沒用的CSS,然后將應用了大量CSS規(guī)則的元素作優(yōu)化。以下是一些來自David Hyatt的針對高效CSS的建議:

避免使用通配規(guī)則(*),星號這種通配符就盡量少或不用,對頁面的渲染影響比較大,直接用ID、類和標簽選擇符比較好。不要限定ID選擇符,文檔中ID就是唯一的,沒必要像這樣:div#top{} ,直接就用#top{}就可以。不要限定類選擇符,比如,將 li.cnt{} 更改為 .li-cnt{}。規(guī)則具體化,避免長串選擇符,最好不要出現 div ul li a{} 類似的選擇符,建議直接用 .li-anchor{},避免使用偽類選擇符(Pseudo-Class),其開銷很高。避免使用子選擇符,如果有像#toc>li>a這樣的基于標簽的子選擇符,那么應該使用一個類來關聯標簽元素,如.toc-anchor。用類選擇符來代替子選擇符。比如你需要給兩個列表來使用不同的樣式:

ul li {color: blue;}

ol li {color: red;}

可以將其改為2個類

.unordered-list-item {color: blue;}

.ordered-list-item {color: red;}

十、將CSS放在文檔標頭處 (Put CSS in the document head)

對于外部CSS文件,瀏覽器會將其完全下載再對頁面進行解析。內聯CSS樣式(在< style >里)也會導致回溯和重解析。因此,建議把所有樣式都放到外部CSS文件里,再將其放在頭部來確保頁面打開時就先下載,有助于加速頁面展現。

HTML 4.01規(guī)范里也建議把CSS都放到里,用Link來調用,而不要用@import來調用。百度統(tǒng)計工具中的“網站速度診斷”功能里也有相應的建議:CSS說明出現在之后,會導致頁面重新渲染,降低網站打開速度。解決方法不難,查一遍可能存在的< style >標簽,挪到之前。

十一、避免在 CSS 中使用 @import (Avoid CSS @import)

在外部的CSS文件中使用@import會使得頁面在加載時增加額外的延遲。雖然規(guī)則允許在樣式中調用@import來導入其它的CSS,但瀏覽器不能并行下載樣式,就會導致頁面增添了額外的往返耗時。比如,第一個CSS文件first.css包含了以下內容:@import url(“second.css”)。那么瀏覽器就必須先把first.css下載、解析和執(zhí)行后,才發(fā)現及處理第二個文件second.css。

簡單的解決方法是使用標記來替代@import,比如下面的寫法就能夠并行下載css文件,從而加快頁面加載速度:

注意的是之前文章提到過一個頁面中的CSS文件不宜過多,否則應該簡化及合并外部的CSS (Combine external CSS) 以節(jié)省往返請求時間(RTT)。

十二、將圖片組合為 CSS 貼圖定位 (Combine images using CSS sprites)

使用CSS貼圖定位,也叫CSS精靈,能減少下載資源時的往返次數、縮減請求的開銷及Web頁面所請求的總字節(jié)數。

原理與減少JavaScript和CSS是一樣的,就是如果網站內有多個圖片,理想情況下是把眾多的可拼合的圖片組織成一個較大的圖,從而減少HTTP請求次數和時間。最常見的一種情況是網站的文本編輯框,里面大量的小圖標,如果網速較慢可看得出一個一個加載顯示,如果能拼合為一張圖片,就能大幅節(jié)省加載時間。那么如何使用CSS sprites,網上有專門的工具可借助,或者自己根據需要去找教程,利用到圖片編輯工具和CSS,稍微麻煩些。

以上內容就是關于SEO性能優(yōu)化之網站速度優(yōu)化(JavaScript和CSS優(yōu)化相關要點)所有內容。

申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

相關文章

熱門排行

信息推薦