可能不一樣團隊都有各自的規範,又或者不少人在寫 CSS 的時候仍是想到什麼就寫什麼,不存在太多的約束。css
我以爲 CSS 代碼規範仍是有存在的必要的,尤爲是在團隊配合,多人協做下,規範就顯得尤其重要。html
本文的所列是實踐當中得出的一套比較不錯的 CSS 書寫規範,並不但願你們徹底採用,而是但願能夠結合本身的團隊須要,發展出一套適合本身的 CSS 代碼規範。git
也但願能夠有更多的建議,共同的完善。本規範也能夠在個人 Github 上看到,歡迎留言或者提 PR。github
我以爲不一樣的規範都有各自的長處與缺陷,對待所謂的規範最好的方式不是人云亦云,拿來就用,而是應該結合實際狀況及需求,取長補短,取其精華去其糟粕。 瀏覽器
採用 UTF-8
編碼,在 CSS 代碼頭部使用:sass
@charset "utf-8";
注意,必需要定義在 CSS 文件全部字符的前面(包括編碼註釋),
@charset
纔會生效。dom
例如,下面的例子都會使得 @charset
失效:ide
/* 字符編碼 */
@charset "utf-8";
html,
body {
height: 100%;
}
@charset "utf-8";
沒有選擇 BEM
這種命名過於嚴苛及樣式名過長過醜的規則,採起了一種比較折中的方案。工具
shift
鍵定義的選擇器名,屬性及屬性值的書寫皆爲小寫。佈局
當一個規則包含多個選擇器時,每一個選擇器獨佔一行。
、+、~、> 選擇器的兩邊各保留一個空格。
.g-header > .g-header-des,
.g-content ~ .g-footer {
}
對於選擇器的命名,儘可能簡潔且具備語義化,不該該出現 g-abc
這種語義模糊的命名。
完整示例以下:
.g-footer,
.g-header {
position: relative;
}
.g-content {
background:
linear-gradient(135deg, deeppink 25%, transparent 25%) -50px 0,
linear-gradient(225deg, deeppink 25%, transparent 25%) -50px 0,
linear-gradient(315deg, deeppink 25%, transparent 25%),
linear-gradient(45deg, deeppink 25%, transparent 25%);
}
.g-content::before {
content: '';
}
當屬性值或顏色參數爲 0 - 1 之間的數時,省略小數點前的 0 。
color: rgba(255, 255, 255, 0.5)
color: rgba(255, 255, 255, .5);
當長度值爲 0 時省略單位。
margin: 0px auto
margin: 0 auto
十六進制的顏色屬性值使用小寫和儘可能簡寫。
color: #ffcc00
color: #fc0
單個樣式規則下的屬性在書寫時,應按功能進行分組,並以 Positioning Model > Box Model > Typographic > Visual 的順序書寫,提升代碼的可讀性。
Positioning 處在第一位,由於他可使一個元素脫離正常文本流,而且覆蓋盒模型相關的樣式。盒模型緊跟其後,由於他決定了一個組件的大小和位置。其餘屬性只在組件內部起做用或者不會對前面兩種狀況的結果產生影響,因此他們排在後面。
在某些樣式中,會出現一些含有空格的關鍵字或者中文關鍵字。
font-family
內使用引號當字體名字中間有空格,中文名字體及 Unicode 字符編碼表示的中文字體,爲了保證兼容性,都建議在字體兩端添加單引號或者雙引號:
body { font-family: 'Microsoft YaHei', '黑體-簡', '\5b8b\4f53'; }
background-image
的 url 內使用引號若是路徑裏面有空格,舊版 IE 是沒法識別的,會致使路徑失效,建議不論是否存在空格,都添加上單引號或者雙引號:
div { background-image: url('...'); }
!important
除去某些極特殊的狀況,儘可能不要不要使用 !important
。
!important
的存在會給後期維護以及多人協做帶來噩夢般的影響。
當存在樣式覆蓋層疊時,若是你發現新定義的一個樣式沒法覆蓋一箇舊的樣式,只有加上
!important
才能生效時,是由於你新定義的選擇器的優先級不夠舊樣式選擇器的優先級高。因此,合理的書寫新樣式選擇器,是徹底能夠規避一些看似須要使用!important
的狀況的。
星號與內容之間必須保留一個空格。
/* 表格隔行變色 */
星號要一列對齊,星號與內容之間必須保留一個空格。
/**
* Sometimes you need to include optional context for the entire component. Do that up here if it's important enough.
*/
使用 // 註釋,// 後面加上一個空格,註釋獨立一行。
.g-footer {
border: 0;
// ....
}
文件頂部必須包含文件註釋,用 @name 標識文件說明。星號要一列對齊,星號與內容之間必須保留一個空格,標識符冒號與內容之間必須保留一個空格。
/**
* @name: 文件名或模塊名
* @description: 文件或模塊描述
* @author: author-name(mail-name@domain.com)
* author-name2(mail-name2@domain.com)
* @update: 2015-04-29 00:02
*/
當該業務項目主要由固定的一個或多我的負責時,須要添加@author標識,一方面是尊重勞動成果,另外一方面方便在須要時快速定位責任人。
使用 SASS
、 LESS
等預處理器時,建議嵌套層級不超過 3 層。
組件/公用類使用 %placeholders
定義,使用 @extend
引用。如:
%clearfix {
overflow: auto;
zoom: 1;
}
.g-header {
@extend %clearfix;
}
使用 SASS ,常常會預先定義好一些經常使用公用組件類,譬如清除浮動,水平垂直居中,文字 ellipsis。又或者多個元素具備一樣的樣式,咱們但願可以少寫這部分代碼,公共部分抽離出來只寫一次,達到複用。
可是複用的方式在 SASS 中有多種,那麼是使用單獨使用一個類定義,給須要的標籤添加,仍是使用 @include
或者 @extend
在定義的類中引入一個 @mixin
,或者一個 @function
呢?
基於讓 CSS 更簡潔以及代碼的複用考慮,採用上面的使用 %placeholders
定義,使用 @extend
引用的方案。
%placeholders
,只是一個佔位符,只要不經過 @extend
調用,編譯後不會產生任何代碼量@extend
引用,則是由於每次調用相同的 %placeholders
時,編譯出來相同的 CSS 樣式會進行合併(反之,若是使用 @include
調用定義好的 @mixin
,編譯出來相同的 CSS 樣式不會進行合併)@mixin
方法進行區分
使用 SASS ,或者說在 CSS 裏也有這種困惑。
假設咱們有以下 html 結構:
<div class="g-content">
<ul class="g-content-list">
<li class="item"></li>
<li class="item"></li>
<li class="item"></li>
<li class="item"></li>
</ul>
</div>
在給最裏層的標籤命名書寫樣式的時候,咱們有兩種選擇:
.g-content {
.g-content-list {
li {
...
}
}
}
或者是
.g-content {
.g-content-list {
.item {
...
}
}
}
也就是,編譯以後生成了下面這兩個,到底使用哪一個好呢?
.g-content .g-content-list li { }
.g-content .g-content-list .item { }
基於 CSS 選擇器的解析規則(從右向左),建議使用上述第二種 .g-content .g-content-list .item { }
,避免使用通用標籤名做爲選擇器的一環能夠提升 CSS 匹配性能。
瀏覽器的排版引擎解析 CSS 是基於從右向左(right-to-left)的規則,這麼作是爲了使樣式規則可以更快地與渲染樹上的節點匹配。
本規範也能夠在個人 Github 上看到,歡迎留言或者提 PR。
到此本文結束,若是還有什麼疑問或者建議,能夠多多交流,原創文章,文筆有限,才疏學淺,文中如有不正之處,萬望告知。