国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

詳解css BEM書寫規(guī)范

2024-07-11 08:59:43
字體:
供稿:網(wǎng)友

BEM是基于組件的web開發(fā)方法。其思想是將用戶界面分隔為獨立的塊,從而使開發(fā)復(fù)雜的UI界面變得更簡單和快,且不需要粘貼復(fù)制便可復(fù)用現(xiàn)有代碼。BEM由Block、Element、Modifier組成。選擇器里用以下連接符擴展他們的關(guān)系:

  • `__:雙下劃線用來連接塊和塊的子元素
  • ` :僅作為連字符使用,連接塊或元素或修飾符的多個單詞(也可以直接寫成駝峰式)
  • --:雙中劃線用來連接塊或元素的狀態(tài)(也可使用‘_’單下劃線表示)

示例:

block-name_modifier-nameblock-name__element-name--modifier-nameblock-name_modifier-name--modifier-valueblock-name__element-name--modifier-name--modifier-value

基本概念

Block(塊)

代碼片段可能被復(fù)用且這段代碼不依賴其他組件即可用Block。塊可以互相嵌套,可以嵌套任意多層。
特點:

  • 塊的名稱用于描述它的目的。如 menu、button
  • 塊不能影響所在環(huán)境。這意味著不能為塊設(shè)置margin或position
  • 只能使用class命名選擇器,而不能使用標(biāo)簽或id選擇器
  • 不依賴于頁面內(nèi)其他塊或元素

Element(元素)

Element是Block的一部分,沒有獨立存在的意義。任何一個Element語義上是和Block綁定的。

特點:

  • 與塊使用'__'連接。 如: block__item
  • 用于描述它的目的。如:item、text
  • 元素可以彼此嵌套,可以嵌套任意多層
  • 元素總是屬于塊的一部分。所以類似于block__item1__item2的命名是不合法的

Modifier(修飾符)

Modifier是Block或Element上的標(biāo)記。使用它們來改變樣式,行為或狀態(tài)。與塊或元素連接符為'--'。

應(yīng)用

相對另外的Blocks定位Block

最好的方式是混合使用block和element。解決block上不能設(shè)置margin、position。

例:

<body class="page">    <!-- header and navigation-->    <header class="header page__header">...</header>    <!-- footer -->    <footer class="footer page__footer">...</footer></body>.page__header {    padding: 20px;}.page__footer {    padding: 50px;}

Block內(nèi)定位Elements

通過額外創(chuàng)建Block的子Element來定位嵌套。

例:

<body class="page">    <div class="page__inner">      <!-- header and navigation-->      <header class="header">...</header>      <!-- footer -->      <footer class="footer">...</footer>    </div></body>.page__inner {    margin-right: auto;    margin-left: auto;    width: 960px;}

關(guān)于命名

選擇器的命名必須完整且精確地描述它代表的BEM實體。

例:

.button {}.button__icon {}.button__text {}.button_theme_islands {}

我們可直接指導(dǎo)我們在處理一個塊元素。在html使用如:

<button class="button button_theme_islands">    <span class="button__icon"></span>    <span class="button__text">...</span></button>

而下面的css就很難讓我們做出相同的判斷:

.button {}.icon {}.text {}.theme_islands {}

在我的git項目miniui中采用了BEM規(guī)范,使用sass實現(xiàn)了BEM。有興趣可以查看:https://github.com/banyaner/miniui

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 长垣县| 青龙| 昌都县| 民县| 唐山市| 隆德县| 岑巩县| 六枝特区| 长顺县| 吴堡县| 广昌县| 康平县| 阳泉市| 平利县| 太仆寺旗| 衡南县| 西青区| 会理县| 绥阳县| 芜湖市| 呼图壁县| 若尔盖县| 鞍山市| 扬州市| 社旗县| 富蕴县| 永兴县| 靖远县| 通许县| 施甸县| 台湾省| 莱州市| 泸水县| 桦南县| 开化县| 磐石市| 葵青区| 安乡县| 印江| 潢川县| 米林县|