iT邦幫忙

第 11 屆 iThome 鐵人賽

DAY 1
0
自我挑戰組

與網頁有關系列 第 1

Day1 關於命名規則-OOCSS、SMACSS、BEM命名規則

  • 分享至 

  • xImage
  •  

OOCSS、SMACSS、BEM命名規則
在了解BEM之前,建議先讀一下關於SMACSS與OOCSS的解釋,熟悉了這兩種方式後再進一步了解BEM,會更加理解命名規則的邏輯思考,可以參考下列兩篇文章

Scalable and Modular
Architecture for CSS

OOCSS

OOCSS
(Object Oriented CSS),有兩項重點:

  1. 分離結構與樣式(Separate container and content):結構是元素標籤,樣式是指顏色,減少依賴結構與樣式間的影響,應該要增加樣式的可重覆性。
  2. 分離HTML與CSS(Separate structure and skin):是指盡量將可共用的樣式單獨抽離出來給class。

BootStrap便是根據OOCSS規範寫的,我們可以觀察bootstrap 的文件

<div class="alert alert-dark alert-dismissible" role="alert">
  A simple primary alert-check it out!
</div>
  • 可看到alert為規範預設的警告樣式
  • alert-dark為規範警告樣式的顏色
  • alert-dismissible 為添增關閉按鈕的樣式

這樣的結構與樣式抽離可以讓開發者透過組合來產生更簡單的維護與管理,這樣若客戶需要改哪邊的小功能時,只需要把部分的零件拿掉,OOCSS追求的是元件的重覆使用。

SMACSS
(Scalable & Modular Architecture for CSS)更具結構與命名規則的限制
透過以下五種分類概念,把class的命成拆的更細節。

  • SMACSS把CSS分成五種結構:(Categorizing CSS Rules):Base、Layout、Module、State、Theme
  • 命名規則:為CSS做分類,id與css的使用不會是獨立性,會透過dash 去做分類,命名規則(Naming Rules)對於SMACSS是很重要的。
  1. Base 基礎規範,是指整份網站文件中,最基礎的規範是什麼,例如reset normalize.css 文件,在這份文件中不會使用到任何class與id,若使用sass,可以直接用@import引入
  2. layout 佈局規範,使指網頁的佈局,例如像是grid網頁佈局的規範,在SMACSS中會使用前綴詞,例如l-list ,其中的"l"代表layout中的 "l",這樣幾個月後再回頭看自己的CSS命名就會很清楚的知道這個layout 代表的是哪邊的list。
  3. Module 模組規範,是指整個網頁的區塊視為一個一個的模組,例如.header-img 前綴詞代表的是模組區塊的名稱,後面代表的是元素名稱。
  4. state 狀態規範,網頁中有不同的狀態顏色或者行為改變所呈現的結果,例如success、error等。
  5. theme 主題規範,是指網頁外觀如顏色、圖片,在SMACSS中不鼓勵使用單獨的 class名稱,可以在這個theme規範中加入網頁顏色來覆蓋掉先前的規範所定義的顏色。

SMACSS比OOCSS 更具語意化,透過分類的方式自己定義class名稱,降低對於html結構的依賴。

BEM
(Block,Element,Modifier),由區塊、元素與修飾狀態
Block是頁面獨立的區塊,每個頁面都可以看成很多區塊的組合。
Element是指區塊中的元素
Modifier 是指描述Block或者Element的屬性或狀態

透過上面三點,結合再一起的class命名就是BEM

.header{   }          // 區塊
.header__element{}   //  區塊 + 區塊裡的元件
.header__element--modifier{}  // 區塊 + 區塊裡的元件 + 狀態

結論
以上三種命名規範,無非圍繞著讓結構更乾淨且容易與內容分離,將可變動與修改的次數比例降低,沒有什麼命名的規則是最好的,只有最適合團隊維護才是最好用的,這邊分享幾項我覺得最基本的命名規則:

  1. 一致性:可分成命名標示與命名邏輯的一致性,無論使用大駝峰、小駝峰或- dash等使用方式,文件規範上一致性是相當重要的,才不會前面是打.header-title,後面突然變成了.headerTitle,讓人看得一頭霧水。
  2. 階層分類:把CSS的階層從上到下的排好,最成功的分類就是一看到命名規則就可以馬上找到所代表的區塊元件,這樣能力是要靠經驗及多寫多練才可以養成的,最好檢視自己進步的方法,就是去看舊的code,若是隔了3個月後,依然可以透過之前的命名很清楚地找到自己寫程式的邏輯,那就代表成功啦!
  3. 方便維護:可以透過小更動就可以更改成自己想要的樣式,這需要透過在class 命名時就要安排好的,例如可以透過只改寫一行就可以更動所有的按鈕顏色,學習pure.css或者bootstrap的文件是個不錯的練習方式喔
<div class="alert alert-dark alert-dismissible" role="alert">
  A simple primary alert-check it out!
</div>
  1. 不要急著寫code,寫code前先把網站的命名邏輯規範思考好,反而會加速自己寫code的速度,命名的重要會隨著code的長度變長而變複雜喔!

下一篇
Day 2 與網頁有關之 Q & A
系列文
與網頁有關2
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
ofcourse448
iT邦新手 5 級 ‧ 2020-06-02 12:08:56

阿咪陀佛

我要留言

立即登入留言