谈谈BEM规范(含代码)
css规范之BEM规范
前言
引用一句经典名言在编程的世界里其中一件最难的事情就是命名,不管是设计到编程语言还是标记语言都会有命名的需求。今天聊的就是关于css的命名规范的发展过程以及演变。
命名的发展变化过程
- 非组件化项目css命名原则
- 复用性 全局性
- 以jquery为代表的时代,我们项目都是独立的html文件,此时为了让我们的项目更好的维护,在写样式的时候,通常我们会将一些通用的样式单独提取到一个css文件,每个页面使用的时候可以引入使用,比如
reset.css,common.css
。 - 每一块功能块的样式都是独立的,之间无法复用,可以复用的样式全部提取到全局样式。
- 组件化项目命名原则
- BEM规范
- 以vue和react为代表的时代,我们项目都是组件化的,组件内的样式都是独立的作用域
scope
来限制,组件之间是可以相互引入使用的,一个组件可以拆分成多个小组件,此时样式命名规范就需要使用BEM规范,从而达到组件样式的独立性。
BEM的规范
- BEM规范是css命名规范,主要适用的范围是组件化开发的模式。
- 规范介绍(B__E--M)
- B
代表block,也就是块,每一个块都是一个独立的功能,块之间可以相互嵌套。
- 块的命名可以由多个单词组成,每个单词之间以
-
链接 - 块的作用只是起到一个隔离的作用,一般不会在块里面实现具体组件的样式,对于块修饰样式比如尺寸,位置可以通过修饰符设置
- 块与修饰符之间通过
--
链接
- 块的命名可以由多个单词组成,每个单词之间以
- E
代表element,也就是元素,元素是依赖于块存在,不能独立存在,必须嵌套在块内部。
- 元素的命名可以由多个单词组成,每个单词之间以
-
链接 - 元素的样式必须依赖块存在,元素是块的具体实现,块与元素之间通过
__
链接 - 元素里面可以定义每个元素自身的样式,对于元素修饰样式比如尺寸,状态可以通过修饰符设置
- 元素与修饰符之间通过
--
链接
- 元素的命名可以由多个单词组成,每个单词之间以
- M
代表modifier, 也就是修饰符,修饰符一般是对于元素或者块的状态和外观进行修饰。
- 修饰符的命名可以由多个单词组成,每个单词之间以
-
链接 - 修饰符可以修饰块和元素的状态、行为、尺寸等
- 修饰符的命名可以由多个单词组成,每个单词之间以
- B
- 代码演示
- 评分组件 源码地址
<div class="qf-rate">
<span class="qf-rate__item qf-rate__item--active">
</span>
<span class="qf-rate__item">
</span>
<span class="qf-rate__item">
</span>
<span class="qf-rate__item">
</span>
<span class="qf-rate__item">
</span>
</div>
.qf-rate{
width: 300px;
height: 40px;
display: flex;
justify-content: center;
align-items: center;
}
.qf-rate__item{
width: 48px;
height: 48px;
cursor: pointer;
background: url('./img/star.png');
}
.qf-rate__item--active{
background: url('./img/star_active.png');
}
- BEM不推荐写法
- 采用标签或者id作为选择器,全部采用类名作为选择器
- id因为权重的问题,而且针对于spa的项目会出现id的重复情况
- 标签选择器当我们需要修改组件解构的时候,同时还需要维护组件样式
- 不推荐使用并列选择器,使用修饰符来实现
- 不推荐使用伪类选择器,使用修饰符来实现
- 此处一般通过js控制状态,添加修饰类
- 不推荐使用全局的css样式比如rest.css common.css
- 但是针对于一些格式化的样式还是可以使用,一切目的都是为了方便维护
- 采用标签或者id作为选择器,全部采用类名作为选择器
总结
BEM规范只是前端组件化发展过程中的规范,都是为了组件化服务,并不是唯一的规范,是否采用这个规范目的是为了团队协作和更好的维护迭代,不是为了规范而规范。
谈谈BEM规范(含代码)的更多相关文章
- 也谈谈规范JS代码的几个注意点
也谈谈规范JS代码的几个注意点 写JS代码差不多也有两年了吧,从刚开始的“初生牛犊不怕虎”乱写一通到后来也慢慢知道去规范一下自己写的代码.这种感觉就像是代码是你的作品,你希望它保持一份不仅干净而且也优 ...
- windows环境PhpStorm中简单使用PHP_CodeSniffer规范php代码
为什么使用PHP_CodeSniffer 一个开发团队统一的编码风格,有助于他人对代码的理解和维护,对于大项目来说尤其重要. PHP_CodeSniffer是PEAR中的一个用PHP5写的用来检查嗅探 ...
- 代码规范、代码复审、PSP
作业三: 代码规范.代码复审.PSP 代码规范 代码规范的重要性 一.规范的代码可以促进团队合作 一个项目大多都是由一个团队来完成,如果没有统一的代码规范,那么每个人的代码必定会风格迥异.且不说会存 ...
- web前端代码规范 - HTML代码规范
Bootstrap HTML编码规范 本文转载自w3cschool. 由于bootstrap得到了世界的认可,因此,此规范用于规范html代码有一定的说服力. 交流qq群:164858883.欢迎各位 ...
- 谈谈关于PHP的代码安全相关的一些致命知识
谈谈关于PHP的代码安全相关的一些致命知识 目标 本教程讲解如何防御最常见的安全威胁:SQL 注入.操纵 GET 和 POST 变量.缓冲区溢出攻击.跨站点脚本攻击.浏览器内的数据操纵和远程表单提交. ...
- javascript基础修炼(4)——UMD规范的代码推演
javascript基础修炼(4)--UMD规范的代码推演 1. UMD规范 地址:https://github.com/umdjs/umd UMD规范,就是所有规范里长得最丑的那个,没有之一!!!它 ...
- 如何使用 Pylint 来规范 Python 代码风格
如何使用 Pylint 来规范 Python 代码风格 转载自https://www.ibm.com/developerworks/cn/linux/l-cn-pylint/ Pylint 是什么 ...
- Python代码规范之---代码不规范,亲人两行泪
任何语言的程序员,编写出符合规范的代码,是开始程序生涯的第一步! 关于代码规范 Python 官方提供有一系列 PEP(Python Enhancement Proposals) 文档 其中第 8 篇 ...
- 个人博客作业Week2(代码规范,代码复审)
Q:是否需要有代码规范 首先我们来搞清楚什么是“代码规范”,它和“代码风格”又有什么关系.依据个人的审美角度,我可能更喜欢在函数与函数之间空出一行,可能在命名习惯和代码注释上更加的internatio ...
随机推荐
- PreparedStatement预编译的sql执行对象
一.预编译,防sql注入 其中,设置参数值占位符索引从1开始:在由sql 连接对象创建 sql执行对象时候传入参数sql语句,在执行对象在执行方法时候就不用再传入sql语句: 数据库索引一般是从1开始 ...
- 深入理解Linux文件系统与日志文件
目录: 一.inode与block 二.inode内容 三.inode的号码 四.inode的大小 五.链接文件 六.inode节点耗尽故障处理 七.恢复EXT类型的文件编译安装extundelete ...
- HearthbuddyHelper已经开源
https://github.com/V-arc/HearthbuddyHelper 只是为了稳定,没耗时多久写的一个中控,只是在逐渐堆加,并未进行重构. 通过写这个感受到自己对异步和wpf的理解还有 ...
- 在springboot pom文件配置过程,`spring-boot-maven-plugin`配置出错的问题解决及配置过程出现问题的一些思考
在springboot pom文件配置过程,spring-boot-maven-plugin配置出错的问题解决及配置过程出现问题的一些思考 解决方法一: 也是最简单的方法,可能是maven没有来得及导 ...
- Tars | 第0篇 腾讯犀牛鸟开源人才培养计划Tars实战笔记目录
腾讯犀牛鸟开源人才培养计划Tars实战笔记目录 前言 在2021年夏,笔者参加了腾讯首届开源人才培养计划的Tars项目,负责Subset流量管理规则的Java语言JDK实现.其中写作几篇开源实战笔记, ...
- CodeForce-702C Cellular Network(查找)
Cellular Network CodeForces - 702C 给定 n (城市数量) 和 m (灯塔数量): 给定 a1~an 城市坐标: 给定 b1~bm 灯塔坐标: 求出灯塔照亮的最小半径 ...
- Python树莓派 爬虫心得
平台: 树莓派 linux 语言:python 搞一个爬虫都清楚是怎么回事,我这里玩过之后有下面的心得: 为什么要用树莓派呢,省电啊,没乱七八糟的桌面问题,可以一直开着. 1.树莓派上的磁盘写入对于不 ...
- npm WARN ajv-keywords@2.1.1 requires a peer of ajv@^5.0.0 but none is installed. You must install peer dependencies yourself.
解决: npm install -g npm-install-peers npm install -g npm npm i ajv 但是好像没啥用
- 『Python』多进程
Python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu_count()查看),在Python中大部分情况需要使用多进程.Python提供了multiprocessin ...
- 项目部署(ubuntu+uwsgi+nginx+supervisor+django)
一.在开发机上的准备工作 1. 确认项目没有bug. 2.设置`ALLOW_HOST`为你的域名,以及ip地址. 4.设置`DEBUG=False`,避免如果你的网站产生错误,而将错误信息暴漏给用户. ...