CSS 命名规范-BEM

文章目录

    • [BEM 介绍](#BEM 介绍)
    • [BEM 简单使用](#BEM 简单使用)

一般来说,解决 css 命名冲突的方案有三种:

  1. 命名约定
  2. css in js
  3. css modules

这里主要介绍的是通过命名约定这种方案,这种方式,就是提供一种命名的标准,来解决冲突

常见的这些标准有:BEM OOCSS AMCSS SMACSS 其他

BEM 介绍

基于组件方式的web开发方法,基本思想是将用户界面分成独立的模块

  1. BEM 是一套针对 css 类样式的命名方法

  2. BEM 的全称是:B lock E lement Modifier

  3. 一个完整的 BEM 类名:block__element--modifier 例如轮播图的下方的点,用于切换展示的图片,其中被选中的点可以命名为 banner__dot--selected

  4. __通常用于连接元素,--通常链接不同的形态

  5. BEM 具体代表什么呢?

  6. block【块】 代表:Block(块),独立的一个实体,独立的意义,通俗点理解就是一个页面中的一个大区域,例如前台首页的 header、banner、news、footer等等,每个页面都可以看做是多个 Block 组成,如图:

  7. element【元素】 代表:block 的一部分,比如一个卡片,卡片的头部和底部可以被命名为 card-header 和 card-footer

  8. modifier【修饰符】 代表:通常表示属性或状态,类似与一种标记同一个 block 或者 element 可以拥有多个 modifier,例如一个标签,可以用于警告,标记成功等等状态,tag_warning、tag_success

  9. 在某些项目中,如果使用 BEM,还可能会增加一个前缀,表示用途,例如:

  10. l:layout 表示这个样式用于布局

  11. c:component 表示这个样式是一个组件,即一个功能区域

  12. u:util 表示这个样式是一个通用的、工具性质的样式

  13. j:JavaScript 表示这个样式没有实际意义,专门提供给 js 获取元素使用的

  14. 在某些公共使用的组件,团队独立封装使用的,还是增加一个标识前缀,例如熟悉的 element-ui,前缀 el

BEM 简单使用

  1. 如果在命名的时候,需要使用多个单词或者拼接,可以使用 - 连接
  2. 在BEM中所有类名都是顶级类名,不提倡嵌套式,更倾向于组件化模式
  3. 以一个进度条组件为例
  1. block:前缀 + block

    html 复制代码
    <div class="jc-progress"></div>
  2. element:具体的元素

    html 复制代码
    <!-- 进度条模块 -->
    <div class="jc-progress">
        <!-- 进度条区域 -->
    	<div class="jc-progress-bar">
            <!-- 进度条外部元素 -->
            <div class="jc-progress-bar__outer">
                <!-- 进度条的内部元素 -->
            	<div class="jc-progress-bar__inner"></div>
        	</div> 
        </div>
        <!-- 进度条信息区域 -->
        <div class="jc-progress-info">
            <!-- 进度条文本 -->
        	<span class="jc-progress-info__text">30%</span>
        </div>
    </div>
  3. modifier:状态,例如进度条的颜色会根据进度改变进度条的颜色,70以内表示正常,70-90之间表示警告,超过90非常危险,那就可以定义三种状态 default、waring、danger,通过三个状态定义颜色值

    html 复制代码
    <!-- 进度条模块 -->
    <div class="jc-progress">
        <!-- 进度条区域 -->
    	<div class="jc-progress-bar">
            <!-- 进度条外部元素 -->
            <div class="jc-progress-bar__outer">
                <!-- 进度条的内部元素  状态为警告 -->
            	<div class="jc-progress-bar__inner--waring"></div>
        	</div> 
        </div>
        <!-- 进度条信息区域 -->
        <div class="jc-progress-info">
            <!-- 进度条文本 -->
        	<span class="jc-progress-info__text">80%</span>
        </div>
    </div>
相关推荐
冻感糕人~3 分钟前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
程序员agions7 分钟前
2026年,“配置工程师“终于死绝了
前端·程序人生
alice--小文子14 分钟前
cursor-mcp工具使用
java·服务器·前端
晚霞的不甘22 分钟前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
小迷糊的学习记录32 分钟前
0.1 + 0.2 不等于 0.3
前端·javascript·面试
梦帮科技1 小时前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
VT.馒头2 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多2 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
C澒2 小时前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
C澒2 小时前
Remesh 框架详解:基于 CQRS 的前端领域驱动设计方案
前端·架构·前端框架·状态模式