成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

CSS如何使用BEM命名規(guī)范-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)CSS如何使用BEM命名規(guī)范,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)公司-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比泗縣網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式泗縣網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋泗縣地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴(lài)。

BEM(塊,元素,修飾符)是基于組件的Web開(kāi)發(fā)的一種前端命名方法論,主要針對(duì)CSS。其背后的想法是將用戶(hù)界面分為獨(dú)立的塊。即使使用復(fù)雜的UI,這也使界面開(kāi)發(fā)變得容易和快速,并且允許重用現(xiàn)有代碼而無(wú)需復(fù)制和粘貼。

優(yōu)勢(shì)

  • 避免樣式?jīng)_突

  • 減小名稱(chēng)長(zhǎng)度

  • 提高可閱讀性

  • 增加樣式重用

怎么使用BEM

Block

一個(gè)功能獨(dú)立的頁(yè)面組件,可以重復(fù)使用

塊不應(yīng)影響其環(huán)境,這意味著您不應(yīng)設(shè)置塊的外部幾何形狀(邊距)或位置

<!--
    good
-->
< div  class = "header" > </ div >

<!--
    bad
    red-text 是描述外觀
-->
< div  class = "red-text" > </ div >

Element

塊的復(fù)合部分,不能單獨(dú)使用

元素全名的結(jié)構(gòu)為block-name__element-name

<!-- 塊 `search-form` -->
<form class="search-form">
    <!-- `input button` 元素 在 `search-form` 塊中 -->
    <input class="search-form__input">
    <button class="search-form__button">Search</button>
</form>

一個(gè)元素始終是塊的一部分,而不是另一個(gè)元素,因此元素名稱(chēng)不可定義為 block__elem1__elem2 的層次結(jié)構(gòu)

<!--
    good
    遵循 `block-name__element-name`
-->
<form class="search-form">
    <div class="search-form__content">
        <input class="search-form__input">
        <button class="search-form__button">Search</button>
    </div>
</form>

<!--
    bad
    ' search-form__content__button ' 不遵循 `block-name__element-name`
-->
<form class="search-form">
    <div class="search-form__content">
        <input class="search-form__content__input">
        <button class="search-form__content__button">Search</button>
    </div>
</form>

元素始終是一個(gè)塊的一部分,您不應(yīng)該與該塊分開(kāi)使用

<form class="search-form">
    <!-- 
        good
        元素在塊 search-form 的里面
     -->
    <input class="search-form__input">
    <button class="search-form__button">Search</button>
</form>

<form class="search-form"></form>
<!--
    bad 
    元素不在塊 search-form 的里面
-->
<input class="search-form__input">
<button class="search-form__button">Search</button>

Modifier

定義塊或元素的外觀,狀態(tài)或行為的實(shí)體

修飾符的兩種類(lèi)型

Boolean

修飾符全名的結(jié)構(gòu)遵循以下模式:

  • block-name_modifier-name

  • block-name--modifier-name

  • block-name_element-name_modifier-name

  • block-name_element-name--modifier-name

<form class="search-form search-form_focused">
    <input class="search-form__input">

    <!-- 'disabled' 是 'button' 的元素 -->
    <button class="search-form__button search-form__button_disabled">Search</button>
</form>

Key-value

修飾符全名的結(jié)構(gòu)遵循以下模式:

  • block-name_modifier-name_modifier-value

  • block-name_modifier-name--modifier-value

  • block-name__element-name_modifier-name_modifier-value

  • block-name__element-name_modifier-name--modifier-value

<form class="search-form search-form_theme_islands">
    <input class="search-form__input">

    <!-- 
        good
        `button` 的修飾符 `size` 的值是 `m` 
    -->
    <button class="search-form__button search-form__button_size_m">Search</button>
</form>

<form class="search-form
             search-form_theme_islands
             search-form_theme_lite">
    <input class="search-form__input">

    <!-- 
        bad
        不可同時(shí)使用兩個(gè)不同值的相同修飾符 
    -->
    <button class="search-form__button
                   search-form__button_size_s
                   search-form__button_size_m">
   </button>
</form>

不能將修飾符與修飾的塊或元素隔離使用。修飾符應(yīng)更改實(shí)體的外觀,行為或狀態(tài),而不是替換它

<!--
    good
-->
<form class="search-form search-form_theme_islands">
    <input class="search-form__input">
    <button class="search-form__button">Search</button>
</form>

<!-- 
    bad
    缺少了塊名稱(chēng) 'search-form' 
-->
<form class="search-form_theme_islands">
    <input class="search-form__input">
    <button class="search-form__button">Search</button>
</form>

在修飾符和元素名稱(chēng)中添加塊名稱(chēng)的好處

  • 有助于減少一個(gè)塊的元素和修飾符對(duì)另一個(gè)塊的實(shí)現(xiàn)的影響

  • 可更清楚的知道修飾符應(yīng)用于該DOM節(jié)點(diǎn)上的哪個(gè)實(shí)體

  • 名稱(chēng)使查找代碼或文件系統(tǒng)中的實(shí)體變得更加容易

什么時(shí)候應(yīng)該用 BEM 格式

  • 使用 BEM 的訣竅是,你要知道什么時(shí)候哪些東西是應(yīng)該寫(xiě)成 BEM 格式的。

  • 并不是每個(gè)地方都應(yīng)該使用 BEM 命名方式。當(dāng)需要明確關(guān)聯(lián)性的模塊關(guān)系時(shí),應(yīng)當(dāng)使用 BEM 格式。

  • 比如只是一條公共的單獨(dú)的樣式,就沒(méi)有使用 BEM 格式的意義:

.hide {
    display: none !important;
}

命名規(guī)范

雙下劃線風(fēng)格
block-name__elem-name--mod-name--mod-val

  • 名稱(chēng)以小寫(xiě)拉丁字母書(shū)寫(xiě)。

  • BEM實(shí)體名稱(chēng)中的單詞由連字符(-)分隔。

  • 元素名稱(chēng)與塊名稱(chēng)之間用雙下劃線(__)分隔。

  • 布爾修飾符用雙連字符(--)與塊或元素的名稱(chēng)分隔。

  • 修飾符的值與其名稱(chēng)之間用雙連字符(--)分隔。

  • (重要提示:注釋?zhuān)?-)中的雙連字符可能會(huì)在HTML文檔驗(yàn)證期間導(dǎo)致錯(cuò)誤。)

CamelCase style
blockName-elemName_modName_modVal

  • 名稱(chēng)以拉丁字母書(shū)寫(xiě)。

  • 名稱(chēng)中的每個(gè)單詞都以大寫(xiě)字母開(kāi)頭。

  • 塊,元素和修飾符名稱(chēng)的分隔符與標(biāo)準(zhǔn)方案中的相同

React命名范式
BlockName-ElemName_modName_modVal

  • 名稱(chēng)以拉丁字母書(shū)寫(xiě)。

  • 塊和元素的名稱(chēng)以大寫(xiě)字母開(kāi)頭。修飾符的名稱(chēng)以小寫(xiě)字母開(kāi)頭。

  • 名稱(chēng)中的每個(gè)單詞都以大寫(xiě)字母開(kāi)頭。

  • 元素名稱(chēng)與塊名稱(chēng)之間用單個(gè)連字符(-)分隔。

  • 修飾符的名稱(chēng)和值之間的分隔符與標(biāo)準(zhǔn)方案中的相同。

沒(méi)有命名空間樣式
_available

  • 名稱(chēng)以拉丁字母書(shū)寫(xiě)。

  • 修飾符之前不包括塊或元素的名稱(chēng)。此命名方案限制了mixs的使用,因?yàn)樗鼰o(wú)法確定修飾符屬于哪個(gè)塊或元素。

常用的CSS命名


例子

vant 組件 css 命名

使用的命名是雙下劃線風(fēng)格:block-name__element-name--modifier-name

<div class="van-doc">
    <div class="van-doc-header">
        <div class="van-doc-row">
            <div class="van-doc-header__top">
                <a class="van-doc-header__logo">搜索</a>
                <ul class="van-doc-header__top-nav">
                    <li class="van-doc-header__top-nav-item">
                        <a class="van-doc-header__logo-link">
                    </li>
                </ul>
            </div>
        </div>
    </div>
    <div class="van-doc-container van-doc-row van-doc-container--with-simulator">
        ......
    </div>
</div>

weui 組件 css 命名

使用的命名是 React命名風(fēng)格:block-name__element-name_modifier-name

<div class="page button js_show">
    <div class="page__hd">
        <h2 class="page__title">Button</h2>
        <p class="page__desc">按鈕</p>
    </div>
    <div class="page__bd">

        <div class="button-sp-area">
            <a class="weui-btn weui-btn_primary">頁(yè)面主操作</a>
            <a class="weui-btn weui-btn_loading">頁(yè)面主操作</a>
            <a class="weui-btn weui-btn_disabled>頁(yè)面主操作</a>
            <a class="weui-btn weui-btn_default">頁(yè)面次要操作</a>
            <a class="weui-btn weui-btn_warn">警告類(lèi)操作</a>
        </div>
        ....
        <div class="button-sp-area cell">

關(guān)于“CSS如何使用BEM命名規(guī)范”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

分享題目:CSS如何使用BEM命名規(guī)范-創(chuàng)新互聯(lián)
瀏覽地址:http://jinyejixie.com/article12/coshgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器面包屑導(dǎo)航、網(wǎng)站維護(hù)網(wǎng)站設(shè)計(jì)公司、網(wǎng)站建設(shè)、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
台南市| 龙州县| 札达县| 平果县| 怀宁县| 乐安县| 织金县| 黄大仙区| 平罗县| 五峰| 达孜县| 玉林市| 利川市| 株洲县| 左云县| 瓦房店市| 连江县| 白银市| 镇坪县| 瑞安市| 上虞市| 峨眉山市| 四平市| 海南省| 白朗县| 泰宁县| 金堂县| 西乡县| 微博| 额尔古纳市| 崇阳县| 简阳市| 合作市| 金昌市| 永靖县| 高台县| 裕民县| 陆良县| 赫章县| 胶州市| 白山市|