文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

CSS如何使用BEM命名规范

2023-06-08 02:54

关注

这篇文章将为大家详细讲解有关CSS如何使用BEM命名规范,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

BEM(块,元素,修饰符)是基于组件的Web开发的一种前端命名方法论,主要针对CSS。其背后的想法是将用户界面分为独立的块。即使使用复杂的UI,这也使界面开发变得容易和快速,并且允许重用现有代码而无需复制和粘贴。

优势

怎么使用BEM

Block

一个功能独立的页面组件,可以重复使用

块不应影响其环境,这意味着您不应设置块的外部几何形状(边距)或位置

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

Element

块的复合部分,不能单独使用

元素全名的结构为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>

一个元素始终是块的一部分,而不是另一个元素,因此元素名称不可定义为 block__elem1__elem2 的层次结构

<!--    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>

元素始终是一个块的一部分,您不应该与该块分开使用

<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

定义块或元素的外观,状态或行为的实体

修饰符的两种类型

Boolean

修饰符全名的结构遵循以下模式:

<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

修饰符全名的结构遵循以下模式:

<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        不可同时使用两个不同值的相同修饰符     -->    <button class="search-form__button                   search-form__button_size_s                   search-form__button_size_m">   </button></form>

不能将修饰符与修饰的块或元素隔离使用。修饰符应更改实体的外观,行为或状态,而不是替换它

<!--    good--><form class="search-form search-form_theme_islands">    <input class="search-form__input">    <button class="search-form__button">Search</button></form><!--     bad    缺少了块名称 'search-form' --><form class="search-form_theme_islands">    <input class="search-form__input">    <button class="search-form__button">Search</button></form>

在修饰符和元素名称中添加块名称的好处

什么时候应该用 BEM 格式

.hide {    display: none !important;}

命名规范

双下划线风格
block-name__elem-name--mod-name--mod-val

CamelCase style
blockName-elemName_modName_modVal

React命名范式
BlockName-ElemName_modName_modVal

没有命名空间样式
_available

常用的CSS命名

例子

vant 组件 css 命名

使用的命名是双下划线风格: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命名风格: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">页面主操作</a>            <a class="weui-btn weui-btn_loading">页面主操作</a>            <a class="weui-btn weui-btn_disabled>页面主操作</a>            <a class="weui-btn weui-btn_default">页面次要操作</a>            <a class="weui-btn weui-btn_warn">警告类操作</a>        </div>        ....        <div class="button-sp-area cell">

关于“CSS如何使用BEM命名规范”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯