CSS代碼規(guī)范

CSS代碼規(guī)范

文檔

CSS 文件使用無(wú) BOM 的 UTF-8 編碼。
使用 2 個(gè)空格做為一個(gè)縮進(jìn)層級(jí)膝捞,不允許使用 4 個(gè)空格 或 tab 字符。
每行不得超過(guò) 120 個(gè)字符愧沟,除非單行不可分割蔬咬。
當(dāng)一個(gè) rule 包含多個(gè) selector 時(shí)求泰,每個(gè)選擇器聲明必須獨(dú)占一行。
/* good */
.post,
.page,
.comment {
  line-height: 1.5;
}

/* bad */
.post, .page, .comment {
  line-height: 1.5;
}
屬性選擇器中的值必須用雙引號(hào)包圍计盒。

不允許使用單引號(hào)渴频,不允許不使用引號(hào)。

/* good */
article[character="juliet"] {
  voice-family: "Vivien Leigh", victoria, female
}

/* bad */
article[character='juliet'] {
  voice-family: "Vivien Leigh", victoria, female
}
屬性定義必須另起一行北启。
/* good */
.selector {
  margin: 0;
  padding: 0;
}

/* bad */
.selector { margin: 0; padding: 0; }
選擇器的嵌套層級(jí)應(yīng)不大于 3 級(jí)卜朗,位置靠后的限定條件應(yīng)盡可能精確。
/* good */
#username input {}
.comment .avatar {}

/* bad */
.page .header .login #username input {}
.comment div * {}
在可以使用縮寫的情況下咕村,盡量使用屬性縮寫场钉。
/* good */
.post {
  font: 12px/1.5 arial, sans-serif;
}

/* bad */
.post {
  font-family: arial, sans-serif;
  font-size: 12px;
  line-height: 1.5;
}
屬性書寫順序

同一 rule set 下的屬性在書寫時(shí),應(yīng)按功能進(jìn)行分組懈涛,并以 Formatting Model(布局方式逛万、位置) > Box Model(尺寸) > Typographic(文本相關(guān)) > Visual(視覺(jué)效果) 的順序書寫,以提高代碼的可讀性批钠。

  • Formatting Model 相關(guān)屬性包括:position / top / right / bottom / left / float / display / overflow 等
  • Box Model 相關(guān)屬性包括:border / margin / padding / width / height 等
  • Typographic 相關(guān)屬性包括:font / line-height / text-align / word-wrap 等
  • Visual 相關(guān)屬性包括:background / color / transition / list-style 等

另外宇植,如果包含 content 屬性,應(yīng)放在最前面埋心。

.sidebar {
  /* formatting model: positioning schemes / offsets / z-indexes / display / ...  */
  position: absolute;
  top: 50px;
  left: 0;
  overflow-x: hidden;

  /* box model: sizes / margins / paddings / borders / ...  */
  width: 200px;
  padding: 5px;
  border: 1px solid #ddd;

  /* typographic: font / aligns / text styles / ... */
  font-size: 14px;
  line-height: 20px;

  /* visual: colors / shadows / gradients / ... */
  background: #f5f5f5;
  color: #333;
  -webkit-transition: color 1s;
  -moz-transition: color 1s;
  transition: color 1s;
}
清除浮動(dòng)

當(dāng)元素需要撐起高度以包含內(nèi)部的浮動(dòng)元素時(shí)指郁,通過(guò)對(duì)偽類設(shè)置 clear 或觸發(fā) BFC 的方式進(jìn)行 clearfix。盡量不使用增加空標(biāo)簽的方式拷呆。
觸發(fā) BFC 的方式很多闲坎,常見(jiàn)的有:

  • float 非 none
  • position 非 static
  • overflow 非 visible
.clear:before,
.clear:after{
    content: " ";
    display: table;
}

.clear:after{
    clear: both;
}

盡量不使用 !important 聲明。

必須注意的是茬斧,僅在設(shè)計(jì)上 確實(shí)不允許任何其它場(chǎng)景覆蓋樣式 時(shí)腰懂,才使用內(nèi)聯(lián)的 !important 樣式。通常在第三方插件環(huán)境的應(yīng)用中使用這種方案项秉。

url() 函數(shù)中的路徑不加引號(hào)绣溜。
RGB顏色值必須使用十六進(jìn)制記號(hào)形式 #rrggbb。不允許使用 rgb()伙狐。帶有alpha的顏色信息可以使用 rgba()涮毫。使用 rgba() 時(shí)每個(gè)逗號(hào)后必須保留一個(gè)空格。
顏色值可以縮寫時(shí)贷屎,必須使用縮寫形式罢防。
顏色值不允許使用命名色值。
顏色值中的英文字符采用小寫唉侄。
必須同時(shí)給出水平和垂直方向的位置咒吐。

2D 位置初始值為 0% 0%,但在只有一個(gè)方向的值時(shí),另一個(gè)方向的值會(huì)被解析為 center恬叹。為避免理解上的困擾候生,應(yīng)同時(shí)給出兩個(gè)方向的值。

/* good */
body {
  background-position: center top; /* 50% 0% */
}

/* bad */
body {
  background-position: top; /* 50% 0% */
}

字體族

font-family 屬性中的字體族名稱應(yīng)使用字體的英文 Family Name绽昼,其中如有空格唯鸭,須放置在引號(hào)中。

所謂英文 Family Name硅确,為字體文件的一個(gè)元數(shù)據(jù)目溉,常見(jiàn)名稱如下:

字體 操作系統(tǒng) Family Name
宋體 (中易宋體) Windows SimSun
黑體 (中易黑體) Windows SimHei
微軟雅黑 Windows Microsoft YaHei
微軟正黑 Windows Microsoft JhengHei
華文黑體 Mac/iOS STHeiti
冬青黑體 Mac/iOS Hiragino Sans GB
文泉驛正黑 Linux WenQuanYi Zen Hei
文泉驛微米黑 Linux WenQuanYi Micro Hei
h1 {
  font-family: "Microsoft YaHei";
}
font-family 按「西文字體在前、中文字體在后」菱农、「效果佳 (質(zhì)量高/更能滿足需求) 的字體在前缭付、效果一般的字體在后」的順序編寫,最后必須指定一個(gè)通用字體族( serif / sans-serif )循未。
需要在 Windows 平臺(tái)顯示的中文內(nèi)容陷猫,其字號(hào)應(yīng)不小于 12px。
font-weight 屬性必須使用數(shù)值方式描述的妖。

CSS 的字重分 100 – 900 共九檔绣檬,但目前受字體本身質(zhì)量和瀏覽器的限制,實(shí)際上支持 400 和 700 兩檔羔味,分別等價(jià)于關(guān)鍵詞 normal 和 bold河咽。

line-height 在定義文本段落時(shí),應(yīng)使用數(shù)值赋元。

將 line-height 設(shè)置為數(shù)值,瀏覽器會(huì)基于當(dāng)前元素設(shè)置的 font-size 進(jìn)行再次計(jì)算飒房。在不同字號(hào)的文本段落組合中搁凸,能達(dá)到較為舒適的行間間隔效果,避免在每個(gè)設(shè)置了 font-size 都需要設(shè)置 line-height狠毯。

.container {
  line-height: 1.5;
}

屬性前綴

帶私有前綴的屬性由長(zhǎng)到短排列护糖。

Hack

需要添加 hack 時(shí)應(yīng)盡可能考慮是否可以采用其他方式解決。
盡量使用 選擇器 hack 處理兼容性嚼松,而非 屬性 hack嫡良。
盡量使用簡(jiǎn)單的 屬性 hack
.coldCity .top {
  top: 24px;
  top: 24px\0; /*ie9-11*/
  top/*\**/: 26px\9; /*ie8*/
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市献酗,隨后出現(xiàn)的幾起案子寝受,更是在濱河造成了極大的恐慌,老刑警劉巖罕偎,帶你破解...
    沈念sama閱讀 212,718評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件很澄,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)甩苛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門蹂楣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人讯蒲,你說(shuō)我怎么就攤上這事痊土。” “怎么了墨林?”我有些...
    開(kāi)封第一講書人閱讀 158,207評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵施戴,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我萌丈,道長(zhǎng)赞哗,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 56,755評(píng)論 1 284
  • 正文 為了忘掉前任辆雾,我火速辦了婚禮肪笋,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘度迂。我一直安慰自己藤乙,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布惭墓。 她就那樣靜靜地躺著坛梁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪腊凶。 梳的紋絲不亂的頭發(fā)上划咐,一...
    開(kāi)封第一講書人閱讀 50,050評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音钧萍,去河邊找鬼褐缠。 笑死,一個(gè)胖子當(dāng)著我的面吹牛风瘦,可吹牛的內(nèi)容都是我干的队魏。 我是一名探鬼主播,決...
    沈念sama閱讀 39,136評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼万搔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼胡桨!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起瞬雹,我...
    開(kāi)封第一講書人閱讀 37,882評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤昧谊,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后挖炬,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體揽浙,經(jīng)...
    沈念sama閱讀 44,330評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡状婶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了馅巷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片膛虫。...
    茶點(diǎn)故事閱讀 38,789評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖钓猬,靈堂內(nèi)的尸體忽然破棺而出稍刀,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評(píng)論 4 333
  • 正文 年R本政府宣布,位于F島的核電站蟆沫,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏局齿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評(píng)論 3 317
  • 文/蒙蒙 一橄登、第九天 我趴在偏房一處隱蔽的房頂上張望抓歼。 院中可真熱鬧,春花似錦拢锹、人聲如沸谣妻。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,864評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蹋半。三九已至,卻和暖如春充坑,著一層夾襖步出監(jiān)牢的瞬間减江,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,099評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工匪傍, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留您市,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,598評(píng)論 2 362
  • 正文 我出身青樓役衡,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親薪棒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子手蝎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容

  • 問(wèn)答題47 /72 常見(jiàn)瀏覽器兼容性問(wèn)題與解決方案? 參考答案 (1)瀏覽器兼容問(wèn)題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,741評(píng)論 1 92
  • css編碼規(guī)范 1代碼風(fēng)格 1.1文件 【建議】css使用無(wú)BOM的UTF-8編碼 解釋:UTF-8編碼具有更廣泛...
    東東丶醬閱讀 325評(píng)論 0 0
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5俐芯? 答:HTML5是最新的HTML標(biāo)準(zhǔn)棵介。 注意:講述HT...
    kismetajun閱讀 27,452評(píng)論 1 45
  • 1. HTML代碼規(guī)范 1.1 命名 class 邮辽、 id 必須單詞全字母小寫,單詞間以 - 分隔。 class...
    芙寶閱讀 1,574評(píng)論 0 7
  • 1 前言CSS 作為網(wǎng)頁(yè)樣式的描述語(yǔ)言吨述,一直有著廣泛的應(yīng)用岩睁。本文檔的目標(biāo)是使 CSS 代碼風(fēng)格保持一致,容易被理解...
    LikySis閱讀 357評(píng)論 0 0