前言

BEM 是一种 CSS class 命名规范. 目的是防止大家名字取太短, 不小撞名字后果很麻烦.

参考:

Youtube – You Probably Need BEM CSS in Your Life (Tutorial)

Battling BEM CSS: 10 Common Problems And How To Avoid Them

结构

<section class="service-section">
<h1 class="service-section__title">Service 1</h1>
<p class="service-section__description">
Lorem ipsum dolor sit amet consectetur adipisicing elit. Recusandae,
omnis.
</p>
<button class="service-section__action service-section__action--focused">
click
</button>
</section>

Block

block 就是一个 namespace 概念, 算是全局命名了, 要确保与页面里其它 block 不能撞,

Element

element 就是元素的语义命名, 比如 title, description, call to action 对比 h1, p, button

有些人不喜欢拿 semantic HTML 来做 selector 所以就有了更语义化的 element.

要确保在整个 block 里面, element 名字不能撞哦.

Modifier

modifier 通常用来表达状态 state, 比如 focused, hovered, 变种 element 的意思.

Sass 结构

.service-section {
&__title {
color: red;
}
&__description {
font-size: 1.5rem;
}
&__action {
text-transform: uppercase;
letter-spacing: 1px;
padding: 0.5rem 1rem; &--focused {
background-color: rgba($color: blue, $alpha: 0.3);
}
}
}

利用嵌套和 & 语法, 虽然 class name 很长, 但 Sass 并没有重复的代码, 看上去还可以.

出来的效果

.service-section__title {
color: red;
}
.service-section__description {
font-size: 1.5rem;
}
.service-section__action {
text-transform: uppercase;
letter-spacing: 1px;
padding: 0.5rem 1rem;
}
.service-section__action--focused {
background-color: rgba(0, 0, 255, 0.3);
}

注意, 它并不是 child selector, .service-section .service-section__title 哦, 而是 flat 的.

我个人是觉得是 ok 的, 毕竟都命名规范了嘛, flat 也不会撞. 但如果想让它变成 .service-section .service-section__title 也是很容易的

#{&}__title {
color: red;
}

加上 Sass 特定语法 #{} 就可以了. 效果:

.service-section .service-section__title {
color: red;
}

常见问题 FAQ:

问: 如果有很多层, 是不是要写成 block__element1_element2_modifier 还是 block1_block2_element_modifier?

答: no, BEM 的结构永远都是 block-name__element-name--modifier, block name, element name 可以用 kebab-case 写长长, 防止撞名字.

问: 不喜欢 class 名字长长, HTML 很丑, 用嵌套 + child selector 的方式可以吗?

答: 是可以的, 关键就是哪个 namespace 的概念要有, 所以 selector 都要有一个 root > child. root 就是 unique 的. 这样就可以保证不会撞了.

我不喜欢 html 写长长的 class. 所以我都是用 child selector 的 (但这样其实风水并没有比较好, 要 100% 顺风水的话还是用 BEM 吧)

替代方案

BEM 的目的是防止 class name 撞名字. 它的解决方式是通过 namespace

我们需要自己管理好 namespace, block 一定要是 unique. 而 block 里面的 element 命名是 block__element 所以防止了和 block 撞名.

有几个方式可以替代这个方案.

1. 用 Tailwind CSS, 因为它的 class 是功能的名字而不是 element 的名字, 自然就不会撞名字了

2. 用 Isolation 方案, 比如 Asp.net Core – CSS Isolation, Angular Component styles

它们的做法就是 compile CSS 和 HTML, 然后加上一些名字. 做法和 BEM 差不多, 只不过是自动的, 不需要人维护.

CSS – BEM (Block__Element--Modifier)的更多相关文章

  1. CSS BEM 命名规范简介

    [前言] BEM 是一个简单又非常有用的命名约定.让你的前端代码更容易阅读和理解,更容易协作,更容易控制,更加健壮和明确,而且更加严密.这篇文章主要介绍了CSS BEM 命名规范简介(推荐)的相关资料 ...

  2. CSS BEM

    CSS BEM Block, Element, Modifier https://en.bem.info/methodology/quick-start/ BEM /* Block component ...

  3. CSS — BEM 命名规范

    推荐阅读: https://juejin.im/post/5b925e616fb9a05cdd2ce70d 1 什么是 BEM 命名规范 Bem 是块(block).元素(element).修饰符(m ...

  4. CSS BEM 命名方式

    简介 简易 css 命名方式,减小命名冲突,使得 css 更有组织感和识别感.但如今写 react 项目大多可以忽略对 css 的命名约束了. 官网介绍:http://getbem.com/intro ...

  5. 面试官:说说你对css效率的理解

    大家好,我是小雨小雨,致力于分享有趣的.实用的技术文章. 内容分为翻译和原创,如果有问题,欢迎随时评论或私信,希望和大家一起进步. 大家的支持是我创作的动力. 选择器的优先级 众所周知,选择器是有权重 ...

  6. 前端规范(ES6BEMOOCSSSMACSS)

    前端规范 在实际开发中,由于团队成员编码习惯不一,技术层次不同,开发前定制并遵循一种代码规范能提高代码质量,增加开发效率. Javascript Javascript规范直接参考airbnb: ES6 ...

  7. Matplotlib数据可视化(3):文本与轴

      在一幅图表中,文本.坐标轴和图像的是信息传递的核心,对着三者的设置是作图这最为关心的内容,在上一篇博客中虽然列举了一些设置方法,但没有进行深入介绍,本文以围绕如何对文本和坐标轴进行设置展开(对图像 ...

  8. CSS命名规范——BEM思想(非常赞的规范)

    人们问我最多的问题之一是在CSS类名中“--”和“__”是什么意思?它们的出现是源于BEM和Nicolas Gallagher... BEM的意思就是块(block).元素(element).修饰符( ...

  9. 好程序员web前端分享值得参考的css理论:OOCSS、SMACSS与BEM

    好程序员web前端分享值得参考的css理论:OOCSS.SMACSS与BEM 最近在The Sass Way里看到了Modular CSS typography一文,发现文章在开头部分就提到了OOCS ...

  10. CSS命名方式=》BEM

    时间:2016-11-04 20:04:53 原文地址:https://github.com/zhongxia245/blog/issues/48 一.背景 挺早就听说过BEM了,也大概的知道怎么用, ...

随机推荐

  1. 持久化技术Mybatis知识精讲【形成知识体系篇】

    环境要求 JDK1.8及以上版本 MySQL数据库 Apache Maven 3.6.1构建工具 IDEA/VSCode/Eclipse开发工具任选其一 思维导图:Xmind ZEN 技术要求 熟悉J ...

  2. 开启GitLab的邮件通知功能以及一些外观配置

    前言 维护GitLab的同事离职了 刚好又有新实习生需要申请账号 只能我来出手了 其实之前安装了 GitLab 之后一直还是用得比较粗糙的 属于是勉强能用的水平,有些配置都还没改好 这次把邮件功能.域 ...

  3. 模型推理batch inference速度无明显提升、耗时线性增长问题排查

    模型推理batch inference速度无明显提升.耗时线性增长问题排查 现象描述 当模型在推理阶段使用batch inference时,推理速度并无明显提升,相比单帧多次推理收益不大.如笔者在Xa ...

  4. 【郝斌C ST】指针 swap问题

    C语言 指针 swap问题 在主函数种实现变量的交换 现在我们把这交换的行为封装进方法中 swap函数确实进行了交换,打印也是10和5了,但是下面a和b的结果还是5和10 - 形参i 和 形参j 并不 ...

  5. 普通用户权限运行docker

    docker安装后默认权限是管理员,在Ubuntu系统中需要使用sudo命令,但是很多时候docker的拉取操作都是写在脚步里面的,因此执行的时候十分的难搞,如果给脚本sudo权限后那么整个的环境路径 ...

  6. 深度学习框架Theano停止维护

    Theano停止开发的声明地址: https://groups.google.com/g/theano-users/c/7Poq8BZutbY/m/rNCIfvAEAwAJ 原文内容: Dear us ...

  7. 为baselines算法库安装mujoco环境支持——ubuntu 20.04安装MuJoCo2.1.1

    下载开源版本的mujoco二进制文件: wget https://github.com/deepmind/mujoco/releases/download/2.1.1/mujoco-2.1.1-lin ...

  8. Python网页应用开发神器fac 0.3.0全新版本发布

    大家好我是费老师,在Python生态中,有很多以Python为主要开发语言,实现网页应用开发的框架,其中最为知名的有Dash.flet.streamlit.gradio.nicegui等. 如果综合考 ...

  9. 原生js操作dom的总结

    一.学习DOM之前需要知道的 1.什么是window? window:是一个全局对象, 代表浏览器中一个打开的窗口, 每个窗口都是一个window对象 2.什么是document?         d ...

  10. 为什么使用#define 而不是用enum定义常量

    typedef enum { IOTAG_PORT__A = (0), IOTAG_PORT__B, IOTAG_PORT__C, IOTAG_PORT__F, IOTAG_PORT__ITEMS } ...