搜尋
首頁web前端css教學css中BEM命名規格是什麼

css中BEM命名規格是什麼

Nov 13, 2020 pm 04:58 PM
css命名規範

css中BEM命名規格是什麼

一什麼是BEM 命名規範

Bem 是區塊(block)、元素(element)、修飾符(modifier)的簡寫,由Yandex 團隊提出的一種前端CSS 命名方法論。

(學習影片分享:css影片教學

- 中劃線:僅作為連字號使用,表示某個區塊或某個子元素的多重單字之間的連接記號。
__ 雙底線:雙底線用來連接區塊和區塊的子元素
_ 單底線:單下劃線用來描述一個區塊或區塊的子元素的一種狀態

BEM 是一個簡單又非常有用的命名約定。讓你的前端程式碼更容易閱讀和理解,更容易協作,更容易控制,更健壯和明確,而且更嚴密。

1. BEM 命名模式

BEM 命名約定的模式是:

.block {}
.block__element {}
.block--modifier {}

每一個區塊(block)名稱應該有一個命名空間(前綴)
block代表了更高層次的抽像或元件。
block__element 代表 .block 的後代,用於形成一個完整的 .block 的整體。
block--modifier 代表.block 的不同狀態或不同版本

使用兩個連字符和下劃線而不是一個,是為了讓你自己的塊可以用單個連字符來界定。如:

.sub-block__element {}
.sub-block--modifier {}

2. BEM 命名法的好處

BEM的關鍵是,可以獲得更多的描述和更清晰的結構,從其名字可以知道某個標記的意思。於是,透過查看 HTML 程式碼中的 class 屬性,就能知道元素之間的關聯。

常規的命名法範例:

css中BEM命名規格是什麼

這種寫法從DOM 結構和類別命名上可以了解每個元素的意義,但無法明確其真實的層級關係。在 css 定義時,也必須依賴層級選擇器來限定約束作用域,以避免跨元件的樣式污染。

使用了BEM 命名方法的範例:

css中BEM命名規格是什麼

透過BEM 命名方式,模組層級關係簡單清晰,而且css 書寫上也不必作過多的層級選擇。

二、如何使用BEM 命名法

1. 什麼時候應該用BEM 格式

使用BEM 的訣竅是,你要知道什麼時候哪些東西是應該寫成BEM格式的。並不是每個地方都應該使用 BEM 命名方式。當需要明確關聯性的模組關係時,應使用 BEM 格式。例如只是一條公共的單獨的樣式,就沒有使用BEM 格式的意義:

.hide {    display: none !important;}

2. 在CSS 預處理器中使用BEM 格式

BEM 的一個槽點是,命名方式長而難看,書寫不雅。相較於 BEM 格式帶來的便利來說,我們應客觀看待。而且,一般來說會使用透過 LESS/SASS 等預處理器語言來編寫 CSS,利用其語言特性書寫起來要簡單很多。

以LESS 為例:

css中BEM命名規格是什麼

3 在流行框架的元件中使用BEM 格式
在目前流行的Vue.js / React / ` Angular 等前端框架中,都有CSS 元件級作用域的編譯實現,其基本原理皆為利用CSS 屬性選擇器特性,為不同的元件產生不同的屬性選擇器。
當你選擇了這種局部作用域的寫法時,在較小的元件中,BEM 格式可能顯得沒那麼重要。但對於公共的、全局性的模組樣式定義,還是建議使用 BEM 格式。
另外,對於對外發布的公共元件來說,一般為了風格的可自訂性,都不會使用這種局部作用域方式來定義元件樣式。此時使用 BEM 格式也會大顯其彩。

4 避免 .block__el1__el2 的格式
在深層嵌套的 DOM
結構下,應避免過長的樣式名稱定義。
層級最後不要超過4 級,不然增加閱讀的理解難度

三、總結

BEM 最難的部分之一是明確作用域是從哪裡開始和到哪裡結束的,以及什麼時候使用或不使用它。隨著不斷使用的經驗積累,你慢慢就會知道怎麼用,這些問題不再是問題。技術無好壞,合適方最好。

推薦寫法與風格

css中BEM命名規格是什麼

css中BEM命名規格是什麼

#相關推薦:CSS教學

#

以上是css中BEM命名規格是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:gxlcms。如有侵權,請聯絡admin@php.cn刪除
丟失的CSS技巧cohost.org丟失的CSS技巧cohost.orgApr 25, 2025 am 09:51 AM

在這篇文章中,布萊克·莫里(Blackle Mori)向您展示了一些駭客,同時試圖推動同位HTML支持的極限。如果您敢於使用這些,以免您也被標記為CSS罪犯。

光標的下一個CSS樣式光標的下一個CSS樣式Apr 23, 2025 am 11:04 AM

具有CSS的自定義光標很棒,但是我們可以將JavaScript提升到一個新的水平。使用JavaScript,我們可以在光標狀態之間過渡,將動態文本放置在光標中,應用複雜的動畫並應用過濾器。

世界碰撞:使用樣式查詢的鑰匙幀碰撞檢測世界碰撞:使用樣式查詢的鑰匙幀碰撞檢測Apr 23, 2025 am 10:42 AM

互動CSS動畫和元素相互啟動的元素在2025年似乎更合理。雖然不需要在CSS中實施乒乓球,但CSS的靈活性和力量的增加,可以懷疑Lee&Aver Lee有一天會成為一種

使用CSS背景過濾器進行UI效果使用CSS背景過濾器進行UI效果Apr 23, 2025 am 10:20 AM

有關利用CSS背景濾波器屬性來樣式用戶界面的提示和技巧。您將學習如何在多個元素之間進行背景過濾器,並將它們與其他CSS圖形效果集成在一起以創建精心設計的設計。

微笑嗎?微笑嗎?Apr 23, 2025 am 09:57 AM

好吧,事實證明,SVG的內置動畫功能從未按計劃進行棄用。當然,CSS和JavaScript具有承載負載的能力,但是很高興知道Smil並沒有像以前那樣死在水中

'漂亮”在情人眼中'漂亮”在情人眼中Apr 23, 2025 am 09:40 AM

是的,讓#039;跳上文字包裝:Safari Technology Preview In Pretty Landing!但是請注意,它與在鉻瀏覽器中的工作方式不同。

CSS-tricks編年史XLIIICSS-tricks編年史XLIIIApr 23, 2025 am 09:35 AM

此CSS-tricks更新了,重點介紹了年鑑,最近的播客出現,新的CSS計數器指南以及增加了幾位新作者,這些新作者貢獻了有價值的內容。

tailwind的@Apply功能比聽起來更好tailwind的@Apply功能比聽起來更好Apr 23, 2025 am 09:23 AM

在大多數情況下,人們展示了@Apply的@Apply功能,其中包括Tailwind的單個property實用程序之一(會改變單個CSS聲明)。當以這種方式展示時,@Apply聽起來似乎很有希望。如此明顯

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。