BEM命名法,其實(shí)很簡單

參考文獻(xiàn):http://www.ibm.com/developerworks/cn/web/1512_chengfu_bem/
http://www.oschina.net/translate/thoughtful-css-architecture

BEM的本質(zhì)是一個(gè)css類名命名方案。由于CSS沒有作用域的概念,也不像SCSS那樣可以寫出層級(jí)關(guān)系,所以,如果有兩個(gè)類名,比如.nav和li,雖然你知道li在.nav中,你也可以寫出.nav li {}這樣的選擇器,但是很多情況下我們還是希望給li專門設(shè)一個(gè)類名,這時(shí)候BEM就是一個(gè)好的方案。

BEM規(guī)范詳解

所謂BEM,其實(shí)是三個(gè)單詞的縮寫:Block(模塊)、Element(元素)、Modifier(修飾符)。

1.Block(模塊)

一個(gè)模塊是一個(gè)獨(dú)立的實(shí)體部分,就像應(yīng)用的一塊“積木”。一個(gè)模塊既可以是簡單的也可以是復(fù)合的(包含其他模塊)。

命名規(guī)范:

模塊名稱可以由拉丁字母,數(shù)字和短劃線組成。 如:.block、.form

比如搜索框和按鈕組成的組件就是一個(gè)模塊。

我認(rèn)為的命名的最佳實(shí)踐是:.xxoo,也就是用兩個(gè)詞組成的詞組來描述這個(gè)塊,比如.propertyeditor或.languageswitcher,前者意思是屬性編輯器,后者是語言切換器。強(qiáng)行用一個(gè)詞來描述的話,你會(huì)發(fā)現(xiàn)詞根本不夠用。

B和M可以直接連用,跳過E,這是允許的。

2.Element(元素)

一個(gè)元素是塊的一部分,具有某種功能。元素是依賴上下文的:它們只有處于他們應(yīng)該屬于的塊的上下文中時(shí)才是有意義的。

比如,.form的input元素和button元素都是元素。

命名規(guī)范:

元素名稱可以包含拉丁字母,數(shù)字,破折號(hào)和下劃線。 CSS類名寫成塊名稱加破折號(hào)加上元素名稱:.block-elem,其中elem可以是直接元素標(biāo)簽名,也是表義的名稱。

我認(rèn)為的最佳實(shí)踐是:比如對(duì)話框內(nèi)有一個(gè)確定按鈕,這個(gè)確定按鈕的類名可以是:.alert-modal__button--done,其中done是修飾符,表示是“表確定的那個(gè)按鈕”。修飾符在下面講。

3.Modifier(修飾符)

修飾符是塊或元素上的標(biāo)志。這些標(biāo)志用來形容元素或塊的外觀、行為或狀態(tài)。例如button、a標(biāo)簽上的active狀態(tài)。

命名規(guī)范:

修飾符名稱可以包含拉丁字母,數(shù)字,破折號(hào)和下劃線。 CSS類名寫成模塊或元素的名稱加上兩個(gè)破折號(hào):.block--mod或.block__elem--mod和.block--color-black。

示例:

.form__submit--disabled

我認(rèn)為的最佳實(shí)踐是:比如對(duì)話框內(nèi)有一個(gè)確定按鈕,這個(gè)確定按鈕的類名可以是:.alertmodal__button--done,其中done是修飾符,表示是“表確定的那個(gè)按鈕”。

小結(jié):

從上面的實(shí)例中,我們不難發(fā)現(xiàn)BEM有以下特點(diǎn):

  • 復(fù)雜的類名極大減少了類名重復(fù)的可能性。
  • 每個(gè)塊里的一類元素的樣式對(duì)應(yīng)一個(gè)類名。如此,一類元素對(duì)應(yīng)一個(gè)類名,減少了子選擇器或后代選擇器的使用,提升了css的性能。
  • css類名的命名更加語義化,更容易讀懂。
  • 可復(fù)用性高,例如我們可以把主題類名.form__theme--xmas替換,即可對(duì)應(yīng)替換為別的主題樣式。

靈活運(yùn)用:

BEM的精華是B、E、M,中間用幾個(gè)連接符都是小事,一般單個(gè)中劃線就可以了,但是,最常見的連接符是bb__ee--mm的形式,盡量遵守這種形式,當(dāng)你遇到其他人寫的規(guī)范的css文檔的時(shí)候,可以降低閱讀難度。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 14,124評(píng)論 1 92
  • BEM 是對(duì) CSS 命名的一種規(guī)范,推崇將 WEB 頁面模塊化,從而提高代碼的重用度,減少后期維護(hù)的成本。原文 ...
    Jadyn閱讀 5,950評(píng)論 0 12
  • 原文 命名約定 若是使用 BEM 實(shí)體,就需要了解它的命名規(guī)則。 命名約定的理念就是使得 CSS 選擇器的命名盡可...
    Jadyn閱讀 2,979評(píng)論 0 0
  • 1.定義# 用原型實(shí)例指定創(chuàng)建對(duì)象的種類,并且通過拷貝這些原型創(chuàng)建新的對(duì)象。在JAVA中通過繼承Clonealbe...
    tdeblog閱讀 342評(píng)論 0 0
  • 我種了一棵小辣椒, 它綠油油, 開出了穿著白色裙子的小花, 結(jié)出了綠色的果實(shí)。 慢慢的, 綠果實(shí)變成了紅辣椒, 切...
    抽風(fēng)一刻閱讀 326評(píng)論 2 2

友情鏈接更多精彩內(nèi)容