CSS的渲染效率-書寫高效的CSS

根據一些CSS寫作經驗,如何提高渲染效率及所占用消耗的資源,我們來淺談一下CSS的渲染效率,書寫高效的CSS。

1、十六進制的顔色值對位數與大小寫

編寫十六進制顔色值時你可能會用小寫字母或省略成3位數,關于這寫法沒找到確實的數據證明對浏覽器的渲染效率是否有影響,但十六進制的顔色值默認標准是大寫及6位數標注。在未知情況下不希望冒險而降低了渲染的效率。

* 不贊成 - color:#f3a;

* 建議用 - color:#FF33AA;

2、display與visibility的差異

他們用于設置或檢索是否顯示對象。display隱藏對象不保留物理空間,visibility爲隱藏對象保留占據的物理空間。當浏覽器渲染被占據的物理空間時,會有所消耗資源。

* 不贊成 - visibility:hidden;

* 建議用 - display:none;

3、border:none;與border:0;的區別

和display與visibility的關系類似,分別不保留與保留空間。更多的是border:0;盡管可以隱藏掉邊框,但它會爲你保留border-color/border-style的使用權。

* 不贊成 - border:0;

* 建議用 - border:none;

4、不宜過小的背景圖片平鋪

一張寬高1px的背景圖片,雖然文件體積非常之小,但渲染寬高500px的板塊需要重複平鋪2500次。提高背景圖片渲染效率跟圖片尺寸及體積有關,最大的圖片文件體積保持約70KB。

* 不贊成 - 寬高8px以下的平鋪背景圖片

* 建議用 - 衡量適中體積及尺寸的背景圖片

5、IE的濾鏡

IE的濾鏡除了比較消耗資源外也有兼容性問題。當中有令PNG透明的濾鏡,可采用GIF或JPG似透非透的辦法來避免使用此濾鏡。建議只在IE6應用GIF透明,因爲IE7以上已經支持了PNG透明。

* 不贊成,濫用IE濾鏡因爲消耗資源外也有兼容性問題。

* 建議用,最好選擇其它方法能避免使用濾鏡。

6、*{ margin:0; padding:0;}避免浏覽器樣式差異

*號通配符把所有標簽都初始化一遍,浏覽器的渲染消耗一定的資源。有部分在標簽在不同浏覽器上幾乎無差異,或是某些已經不推薦使用的標簽(因爲你不會去用它),它們不需通配符要重新初始化一遍這樣做能節省一點資源。

* 不贊成,使用*號通配符

* 不贊成,div span button b table等標簽納入通配符控制內外填充樣式

* 建議用,有選擇性地使用通配符控制內外填充樣式。

7、不要添加額外的標簽來描述class或id

如果你有一個選擇器是以id作爲關鍵選擇符,請不要添加多余標簽名上去。因爲ID是唯一的,你不要爲了一個不存在的理由而降低了匹配的效率。

* 不贊成 - button#backButton { }

* 不贊成 - .menu-left #newMenuIcon { }

* 建議用 - #backButton { }

* 建議用 - #newMenuIcon { }

8、盡量選擇最特殊的類來存放選擇器

降低系統效率的一個最大原因是我們在標簽類中用了過多的選擇符。通過添加 class 到元素,我們可以將類別進行再細分爲 class 類,這樣就不用爲了一個標簽浪費時間去匹配過多的選擇符了。

* 不贊成 - treeitem[mailfolder=”true”] > treerow > treecell { }

* 建議用 - .treecell-mailfolder { }

9、避免子孫選擇符

子孫選擇符是CSS中最耗資源的選擇符。他真的是非常的耗資源,尤其是在選擇器使用標簽類或通用類的時候。很多情況中,我們真正想要的是子選擇符。除非有明確說明,在 UI CSS 中是嚴禁使用子孫選擇符的。

* 不贊成 - treehead treerow treecell { }

* 好一點,但還是不行(參照下一條) - treehead > treerow > treecell { }

10、標簽類中不要包含子選擇符

不要在標簽類中使用子選擇符。否則,每次元素的出現,都會額外地增加匹配時間。(特別是當選擇器似乎多半會被匹配的情況下)

* 不贊成 - treehead > treerow > treecell { }

* 建議用 - .treecell-header { }

11、留意所有子選擇符的使用

小心地使用子選擇符。如果你能想出一個的不使用他的方法,那麽就不要使用。特別是在 RDF 樹和菜單會頻繁地使用子選擇符,像這樣。

* 不贊成 - treeitem[IsImapServer=”true”] > treerow > .tree-folderpane-icon { }

請記住 RDF 的屬性是可以在模板中被複制的!利用這一點,我們可以複制那些想基于該屬性改變的子 XUL 元素上的 RDF 屬性。

* 建議用 - .tree-folderpane-icon[IsImapServer=”true”] { }

提高CSS的網頁渲染效率
  CSS學習越深入,我們需要關注的細節之處就越多,今天我們通過11個注意點來提高CSS的網頁渲染效率。  1、十六進制的顔色值對位數與大小寫  編寫十六進制顔色值時你可能會用小寫字母或省略成3位數,關于這寫法...查看完整版>>提高CSS的網頁渲染效率
 
書寫高效的樣式表(CSS)的方法
  CSS 被吹捧的好處之一就是它能減小頁面大小,由此縮短下載時間,不僅僅是首頁的載入,還包括樣式表被緩存以後,後續頁面的載入也被加快了的那部分時間。這沒錯,但首頁載入時間的縮短幾乎看不出來,這是因爲 CSS...查看完整版>>書寫高效的樣式表(CSS)的方法
 
書寫高效的樣式表(CSS)的方法
  CSS 被吹捧的好處之一就是它能減小頁面大小,由此縮短下載時間,不僅僅是首頁的載入,還包括樣式表被緩存以後,後續頁面的載入也被加快了的那部分時間。這沒錯,但首頁載入時間的縮短幾乎看不出來,這是因爲 CSS...查看完整版>>書寫高效的樣式表(CSS)的方法
 
CSS教程:用好CSS的五個書寫技巧-css設計
nettuts帶來的5個css書寫技巧,簡單翻譯一下它的中心思想。1. CSS Reset/重置你也許需要先了解什麽是css重置。然後怎麽樣寫css重置呢。你可以copy Eric Meyer Reset, YUI Reset或其它css reset, 但你接下來應該根據你...查看完整版>>CSS教程:用好CSS的五個書寫技巧-css設計
 
淘寶的css屬性順序書寫規範
很有啓示作用,可以參考。段正淳 from Taobao.com UED Team 以前部門的同事們,每個人都有一套書寫的規範,導致看對方的css代碼非常吃力,所以就推行了一套書寫標准 ,或許對您也有幫助。*{ /*顯示屬性*/ display po...查看完整版>>淘寶的css屬性順序書寫規範
 
CSS樣式表設計注釋書寫規範詳解-css設計
總結了一下自己工作中使用到的注釋書寫規範,沒有什麽技術含量,只是用于統一制作方式,方便維護。包含了“區域注釋”、“單行注釋”、“注釋層級”和“協助注釋”四個部分。如果大家有其它的建議,歡迎留言。大部分...查看完整版>>CSS樣式表設計注釋書寫規範詳解-css設計
 
提高網頁的維護更新效率(CSS篇)
  隨著互聯網經濟的不斷發展,互聯網上的專業網站、公衆服務網站以及企業門戶的數量都在飛速的增長,各網站的信息量也呈爆炸性增長的趨勢。面對這些龐大的信息量,我們對網頁中每一個欄目的增刪,都會是一個很複雜...查看完整版>>提高網頁的維護更新效率(CSS篇)
 
提高網頁的維護更新效率(CSS篇)
  隨著互聯網經濟的不斷發展,互聯網上的專業網站、公衆服務網站以及企業門戶的數量都在飛速的增長,各網站的信息量也呈爆炸性增長的趨勢。面對這些龐大的信息量,我們對網頁中每一個欄目的增刪,都會是一個很複雜...查看完整版>>提高網頁的維護更新效率(CSS篇)
 
如何高效的學習css
  不知從何時開始,CSS開始爲國人重視起來。許多人都開始學習CSS,但又不知從何入手,所以此文就是給那些初學者所寫,帶他們踏上CSS列車。  一. CSS學習重在方法!  學習任何東西都是一樣,從小學、中學、大學,...查看完整版>>如何高效的學習css
 
 
回到王朝網路移動版首頁