首页 > 其他分享 >CSS架构之BEM设计模式

CSS架构之BEM设计模式

时间:2023-02-20 14:07:30浏览次数:42  
标签:BEM Element CSS 命名 设计模式 Block


为什么需要CSS架构?

其实在日常开发CSS当中,会遇到许多的问题,使用设计模式能够很好的解决。例如在日常开发项目,需要组件化时,组件内部的class样式类管理就非常的杂乱。 大部分公司的命名规则还是只有大小驼峰、使用英文等这些基础的命名规则。经常会自己都忘了自己命名的css是啥,使用设计模式就能很好的解决该问题。

CSS架构也能让html与css更好的解耦,能更好的抽取样式中可复用的部分,使你的html代码更具语义,也符合了HTML5中想让日常开发更具有语义化的理念。了解这些设计模式无疑会使css代码更具模块化,块样式不依赖于页面上的其他元素,因此也较好的避免了遇到级联问题。多人协作的时候,也能高效避免命名重复问题。最重要是提取精华,灵活应用,更加的规范规模化,在达到提高效率的同时兼顾性能。

最重要的是,不用再为命名CSS绞尽脑汁了。

BEM的简介

BEM就是:

  • B代表:Block(块),独立实体,独立的意义,每个页面都可以看做是多个Block组成,见下图1-1;
  • E代表:Element(元素),block 的一部分,没有独立意义,是组件下的一个元素,多个元素形成一个组件,见下图1-2;
  • M代表: Modifier (修饰符),block 或 element 上的标记,是描述Block或Element的属性或状态,同一Block或Element可以有多个Modifier。

BEM全称BlockElementModifier是由Yandex(俄罗斯最著名的互联网企业)的开发团队提出的前端开发理论。通过Block、Element、Modifier来描述页面,通过 ​​_​​​ 与 ​​--​​ 连接 ,关键就是为了解决多人协作的命名问题。

CSS架构之BEM设计模式_css

[1-1.block图解]

CSS架构之BEM设计模式_架构_02

[1-2.Element图解]

BEM的基础使用

模块block()

没有前缀,多个单词用 ​​-​​ 连接,是对一个组件名抽象。

例如:

//一个普通列表的a标签
<li><a class='li-a'>...</a></li>

//一个在导航栏的a标签
<li><a class='nav-li-a'></a></li>

//一个被选中的在导航栏的a标签
<li><a class='nav-li-a is-active'></a></li>

//一个在头部的图片
<header>
<img class="header-img" src="#" alt="#">
</header>

元素Element

元素在模块之后,可以有多个层级,以 ​​__​​​ 连接。element 也不是死板的,是根据具体的需求演变的,中间也可以使用 ​​-​​ 来演变。

<li class="nav--main__item  js-nav--main__item"><a>...</a></li>
<li class="nav--main__item js-nav--main__item"><a>...</a></li>
<li class="nav--main__item js-nav--main__item"><a>...</a></li>
//几个普通列表的a标签
<li>
<a class='li-a__item'>...</a>
<a class='li-a__item'>...</a>
<a class='li-a__item'>...</a>
</li>
//几个在导航栏的a标签
<li>
<a class='nav-li-a__item'></a>
<a class='nav-li-a__item'></a>
<a class='nav-li-a__item'></a>
</li>

修饰Modifier

某元素、或者某模块特别的状态,必须有一个状态名和状态值,使用 ​​_​​ 链接

主要针对的是 Block 本身,是对于Block做修饰。例如有:

  • 颜色
  • 大小
  • 用途

案例:

//一个用作logo的图片
<header>
<img class="header-img_logo" src="#" alt="#">
</header>

使用BEM的好处

  • 使html代码更具语义
  • 使css代码更具模块化
  • 多人协作的时候,也能高效避免命名重复问题
  • 更加的规范规模化
  • 减轻CSS命名烦恼


标签:BEM,Element,CSS,命名,设计模式,Block
From: https://blog.51cto.com/u_15967048/6068463

相关文章

  • HTML5+CSS3(十)-全面详解(学习总结---从入门到深化)
    ​​Display​​​​编辑 元素隐藏属性对比​​​​学习效果反馈 ​​​​文档流 ​​​​文档流产生的问题 ​​​​空格折叠​​​​元素无空隙​​​​脱离文档流​......
  • 责任链和策略设计模式-基于Java编程语言
    作者:京东物流钟磊1前言最近在梳理接口逻辑的时候发现,代码中使用的策略和责任链设计模式给我留下了非常深刻的印象。一个业务逻辑流程通常非常适合使用责任链和策略设计......
  • 看完这篇原型设计模式,还不会,请你吃瓜
    概述使用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。在软件系统开发中,有时候会遇到这样的情况:我们需要用到多个相同实例,最简单直接的方法是通过多次......
  • CSS背景过滤器-毛玻璃属性(backdrop-filter)
    例如做一个边框特效@keyframeshuerotate{0%{filter:hue-rotate(0deg);}100%{filter:hue-rorate(360deg);}}.border{border-bottom:1p......
  • 设计模式(十)----结构型模式之适配器模式
    1、概述如果去欧洲国家去旅游的话,他们的插座如下图最左边,是欧洲标准。而我们使用的插头如下图最右边的。因此我们的笔记本电脑,手机在当地不能直接充电。所以就需要一个插......
  • 设计模式之观察者模式
    spring的观察者模式demo1.观察者模式与发布与订阅模式对比:观察者模式比较概念的解释是,目标和观察者是基类,目标提供维护观察者的一系列方法,观察者提供更新接口。具体观察......
  • 设计模式入门
    1、简介  设计模式(Designpattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这......
  • 设计模式-简单工厂
    api.h#pragmaonce#include<string>#include<iostream>classAPI{public: virtualvoidrun(std::string)=0;protected: API(){};};classBAPI:publ......
  • 设计模式-原型模式
    原型模式(PrototypePattern):使用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。原型模式是一种对象创建型模式应用实例描述如下:未使用原型模式#inc......
  • 设计模式-建造者模式
    业务场景未使用建造者模式实现#include<iostream>#include<string>#include<vector>#include<sstream>usingnamespacestd;template<classT>stringConvertTo......