[译] CSS使用BEM命名规范的五大理由

前言

BEM命名规范无疑是优秀的,它能够防止你的CSS代码陷入混乱,难以维护。当我刚接触到BEM的时候,我一下子就喜欢上了这种规范,下面我将给大家分享下。

CSS是一门易于书写并容易理解的语言,但如果要在一个大型的项目中保持你的CSS代码整洁,易于维护却不是一件容易的事情,很多人往往把它写的杂乱无章。很多时候,你需要理解某部分代码时,你可能需要从头开始读起。这种场景是不是似曾相似呢?也许这个时候就需要一套规范让大家共同遵守了。常见的规范很多,每个人的选择可能也不一样,而我则选择使用BEM命名规范

来源: Mat Przegiętka

图片来源: Mat Przegiętka

BEM是什么?

BEM是一种CSS类命名规范,通过 模块化可维护 的方式 编写样式

BEM是 块(Block),元素(Element),修饰符(Modifier)的缩写。

例如:'block__element--modifier'

类的命名总是以块名开始,然后是元素名(可选,前面加两个下划线),最后是修饰符(也可选,前面加两个破折号)。

图1:在BEM中命名的组件示例

块(Block)

块是一个独立的,可重复使用的模块 , 你可以将其视为前端框架中的组件。例如,一个上图示例的"card"就是一个很典型的块。

注意:避免使用特定内容的命名(比如“shopping-list”),推荐使用通用的名称(比如“check-list”),以便在不同的场景中复用它们(“check-list”和“todo-list”)。

元素(Element)

元素是只存在于其块内的元素。

比如上图示例中的card__title,card__textcard__button

注意:元素嵌套只能有一个层级,所以card__button__text是不可行的。你应该定义另一个名为“button”的块(由button__text组成)。

修饰符(Modifier)

修饰符可以为块或元素提供额外的描述,如颜色,状态等。

通过这种方式,我们可以有像card__button--primary这样的card--featured类。

注意:修饰符只能进行修饰,并总是伴随着基础块。对于card,它将是:“card card--featured”,其中基础块定义了内边距和边框,而修饰符则定义了背景颜色。

图2:修饰符示例

  • 除了BEM三个核心部分,你还可以给类添加 命名空间 前缀

想深入理解可点击 getbemNaming convention 。此外,还有一些 相关博文

BEM 有哪些优势

广泛认可

BEM是最受开发者认可的命名规范之一。也就是说,当你为你的BEM项目引入新的开发成员时,他们很有可能已经了解过这一规范,从而缩短了学习和适应的过程,从而让他们快速投入开发

可读性强

每个元素都有语义化的类名,这样CSS样式表可读性非常强。选择器不仅阅读起来更舒适,也比多层嵌套的写法运行效率更高。

图3:语义化的BEM命名 VS 标签选择器

扩展性强

CSS选择器的粒度足够地细,改动时就变得非常简单。只需要修改一个选择器就够了,也不用担心两个选择器之间产生的权重问题

图4:重写二级菜单图标的样式(BEM与嵌套标签)

适应性强

模块化复用的理念,让BEM很容易配合其他框架一起使用。 此外,样式与元素类型和嵌套无关,不会打乱文档结构。

图5:元素类型和嵌套的重要性(BEM与标签))

健壮性

计算机科学只有两件事难以处理:缓存失效和命名。
—— Phil Karlton

当你开始使用BEM时,你可能会发现自己会有许多疑虑
这反而是一件好事:

  1. 使用合适的块命名让你的代码清晰易读,别人更容易理解(也包括你以后自己理解)

  2. 相似的模块推荐复用已有的类名

  3. 避免多级嵌套

简而言之,它会促使你开始注意细节,思考问题,从而提高代码的质量。 准备好使用BEM了吗?

译者:由于本人水平有限,翻译的内容难免有错漏和理解偏差之处,欢迎各位大神指正

原文:blog.elpassion.com/reasons-to-…

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值