CSS代碼風(fēng)格規(guī)則CSS代碼有效性
使用有效的CSS代碼。
可使用W3C CSS validator來(lái)驗(yàn)證css。
命名
class應(yīng)優(yōu)先慮以這元素具體目的來(lái)進(jìn)行命名,應(yīng)盡量簡(jiǎn)短且富有含義。
統(tǒng)一采用小寫(xiě)英文字母、數(shù)字、“-” 的組合。其中不得包含漢字、空格和特殊字符。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .demoimage {} /* "demo" 和 "image" 中間沒(méi)加 "-" */</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .error_status {} /* 用下劃線(xiàn) "_" 是屌絲的風(fēng)格 */</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .ads-sample {}</font>
復(fù)制代碼
原則上,不建議縮寫(xiě),除非一看就懂的縮寫(xiě),如nav。
盡量避免使用id來(lái)控制樣式。
框架css類(lèi)命名清單
- 全屏:full_bg(全屏背景)
- 容器:wrapper(最外面的主框架)
- 頁(yè)頭:header(子項(xiàng):h_1、h_2、……)
- 內(nèi)容:container
- 頁(yè)面主體:main
- 頁(yè)尾:footer
- 導(dǎo)航:nav(子項(xiàng):n_1、n_2、……)
- 菜單:menu(子項(xiàng):m_1、m_2、……)
- 導(dǎo)航:nav(子項(xiàng):n_1、n_2、……)
- 子菜單:submenu
- 側(cè)欄:sidebar
- 欄目:column(擴(kuò)展:column1、column2、……)
- 左右中:left、right、center
- 搜索:search
- 登陸:signin
選擇器
避免出現(xiàn)過(guò)多的祖先選擇器,各瀏覽器會(huì)有性能差異,消耗在選擇器的時(shí)間也不盡相同。
盡量最多控制在3級(jí)以?xún)?nèi)。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- ul.example {}
- .example1 .example2 .example3 .example4 {}</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example {}
- .example1,
- .example2 {}</font>
復(fù)制代碼
非必要的情況下不要使用元素標(biāo)簽名和ID或class進(jìn)行組合。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- ul#example {}
- div.error {}</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- #example {}
- .error {}</font>
復(fù)制代碼
簡(jiǎn)化css
寫(xiě)屬性值的時(shí)候盡量使用縮寫(xiě)。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .example {
- border-top-style:none;
- font-family:Palatino, serif;
- font-size:100%;
- line-height:1.6;
- padding-bottom:2em;
- padding-left:1em;
- padding-right:1em;
- padding-top:0;
- }</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example { border-top: none; font: 100%/1.6 Palatino, serif; padding: 0 1em 2em;}</font>
復(fù)制代碼
屬性值為0時(shí),忽略單位
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .example { margin:0px; padding:0px;}</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example { margin:0; padding:0;}</font>
復(fù)制代碼
屬性值出現(xiàn)小數(shù)點(diǎn)忽略0
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .example { font-size:0.8em}</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example { font-size:.8em}</font>
復(fù)制代碼
省略URI外的引號(hào)
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .example { background-image: url("images/noise.png");}</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example { background-image: url(images/noise.png);}</font>
復(fù)制代碼
十六進(jìn)制盡可能使用3個(gè)字符
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .example { color: #eebbcc; }</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example { color: #ebc; }</font>
復(fù)制代碼
Hacks
盡可能地避免使用hack的方式解決瀏覽器樣式兼容性問(wèn)題。
盡量避免使用CSS filters。
CSS代碼格式規(guī)則單行書(shū)寫(xiě)
一個(gè)類(lèi)一行,每個(gè)屬性間用空格隔開(kāi),不用強(qiáng)制換行。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .example {
- display:block;
- float:left;
- width:200px;
- height:300px;padding:10px;
- }</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .example { display: block; float: left; width: 200px; height: 300px; padding: 10px;}</font>
復(fù)制代碼
分隔選擇器
每個(gè)選擇器和聲明都要獨(dú)立新行。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- a:focus, a:active { position: relative; top: 1px;}</font>
復(fù)制代碼
- /* 推薦 */
- h1,
- h2,
- h3 { font-weight: normal; line-height: 1.2;}
復(fù)制代碼
屬性名完結(jié)
出于一致性的原因,在屬性名和值之間加一個(gè)空格(可不是屬性名和冒號(hào)之間噢)。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- h3 { font-weight:bold;}</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- h3 { font-weight: bold; }</font>
復(fù)制代碼
聲明完結(jié)
考慮到一致性和拓展性,請(qǐng)?jiān)诿總€(gè)聲明尾部都加上分號(hào)。
- <font color="rgb(51, 51, 51)" size="3">/* 不推薦 */
- .test {
- display: block;
- height: 100px
- }</font>
復(fù)制代碼
- <font color="rgb(51, 51, 51)" size="3">/* 推薦 */
- .test { display: block; height: 100px;}</font>
復(fù)制代碼
css書(shū)寫(xiě)順序
書(shū)寫(xiě)順序按顯示屬性,自身屬性, 文本屬性順序。
顯示屬性
- display
- list-style
- position
- float
- clear
自身屬性
- width
- height
- margin
- padding
- border
- background
文本屬性
- color
- font
- text-decoration
- text-align
- vertical-align
- white-space
Css Meta規(guī)則編碼
一般情況下編碼同html的一致。
如果是urf-8,則不需要制定樣式表的編碼,因?yàn)樗J(rèn)為urf-8。
注釋頭部注釋
注明本CSS的用處,生成時(shí)間及作者等信息。
- <font color="rgb(51, 51, 51)" size="3">/* CSS Document
- Use for: website
- Version: 1.0
- Date: time
- Author: your name
- Update:
- */</font>
復(fù)制代碼
頁(yè)面注釋
有時(shí)候一份CSS會(huì)把首頁(yè)和各種二級(jí)頁(yè)面樣式寫(xiě)在一起,這時(shí)需要做頁(yè)面注釋。
- <font color="rgb(51, 51, 51)" size="3">/***********************************
- * 首頁(yè)
- ***********************************/</font>
復(fù)制代碼
分級(jí)注釋
比如在main模塊下,建立了news、photo等欄目,可使用分級(jí)注釋?zhuān)灾该鲗蛹?jí)結(jié)構(gòu)。
- <font color="rgb(51, 51, 51)" size="3">/*----------------main-----------------*/
- #main {}
- .main-bg {}
- /* news */
- .news {}
- /* photo */
- .photo {}</font>
復(fù)制代碼
區(qū)塊間注釋
- <font size="3">/* news */
- .news {}
- /* photo */
- .photo {}</font>
復(fù)制代碼
修改注釋
當(dāng)后期維護(hù)中有修改到css,需添加修改的注釋。
- <font color="rgb(51, 51, 51)" size="3">.news {} /* 修正橫向滾動(dòng)條錯(cuò)誤 by your name */</font>
復(fù)制代碼
|