CSS中的BEM命名约定

首页 / 常见问题 / 低代码开发 / CSS中的BEM命名约定
作者:软件开发平台 发布时间:01-05 18:05 浏览量:7502
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

CSS中的BEM(Block Element Modifier)命名约定是一种用于前端开发的命名方法,它旨在通过结构化的类名增强HTML和CSS的可读性和复用性。其核心观点包括块(Block)、元素(Element)、修饰符(Modifier)。块是构成页面的独立组件,元素是块的一部分,而修饰符则用于表示块或元素的不同状态或版本。BEM命名的精髓在于提供一种清晰、一致的语法结构,有助于团队协作、代码维护和开发效率。

BEM的命名模式通常呈现为block__element--modifier的形式。其中是功能独立的组件,它可以是简单的按钮,也可以是复杂的网站头部。块在不同的页面或上下文中应该看起来和功能一致,这是达到高复用性的关键。每一个独立的块都应当有一个清晰、具体的名字,比如.button.menu.header 等。

一、块(Block)的概念和使用

代表了一个独立的、具有高度可复用性的模块,它可以包含其他块或元素。在BEM命名中,块的名称通常使用单词全称,中划线用于连接多个单词,例如.content-section.navigation-menu

块是CSS中的BEM命名约定的基础,要求块的命名应简明、直观,并体现出其功能。块不依赖于任何外部样式,其样式不应受页面上其他元素的影响。比如一个.button块,定义了一个按钮的基础样式,它可以在页面中任何地方使用,而外观和行为应当保持一致。

二、元素(Element)的概念和使用

在BEM中,元素是块内部的组成部分,无法脱离块单独存在。它们是块的子代,并通过两个下划线与所属块的名字相连接,例如.block__elementelement在这里是元素的名字,而block是它所属的块的名字。

元素用于构成块的结构,它们反映出块内部的组织方式。举个例子,.header__logo表示header块内的logo元素。元素样式仅关联其所属的块,这样可以避免元素样式被其他块的样式影响。以避免潜在的样式冲突和增加样式的可预测性。

三、修饰符(Modifier)的概念和使用

修饰符是BEM中的第三个组成部分,用于描述块或元素的不同状态、样式或行为。它以两个连字符--连接在块或元素的名字后面,例如.block--modifier.block__element--modifier

修饰符使得可以在不改变原有块或元素结构的基础上,赋予它们不同的外观或行为。如.button--large代表一个大号按钮样式,而.list__item--active则表示列表项的活动状态样式。修饰符的使用提高了代码的灵活性,同时保持了结构的清晰度。

四、实际应用案例分析

为了展示BEM命名约定的实践价值,我们可以考虑以下几个应用案例:

  1. 网站导航菜单(Navigation Menu):定义一个.navigation块,其下可能会有.navigation__item元素表示各个菜单项,以及.navigation__link元素表示链接。根据菜单状态,我们可能还需要.navigation--expanded修饰符表示菜单展开。
  2. 搜索表单(Search Form):这里.search-form可以作为块,它包含.search-form__input用于文本输入和.search-form__button用于提交搜索。修饰符.search-form--with-autocomplete可用于指示表单具有自动补全的功能。

五、BEM与预处理器结合使用

BEM命名与CSS预处理器如Sass或Less的结合使用,能够大幅提升样式的组织和复用性。预处理器支持嵌套规则,这让我们能将元素和修饰符的样式直接嵌套在块的样式内部,代码会更加整洁。

在使用预处理器时,我们通常会创建用于每个块的独立文件。例如,对于.button块,我们会有一个_button.scss文件,内部包含了所有相关的元素和修饰符样式。预处理器的变量和混合宏(mixins)也能帮助我们灵活定义重复使用的样式片段,进一步提升开发效率。

六、BEM命名的最佳实践

BEM命名约定虽然强大,但在实践中也有一些最佳实践需要注意:

  1. 保持简洁:尽量使用短而有意义的名字,避免过长的类名。
  2. 通用性与具体性的平衡:在命名块时,要考虑它的复用潜力。对于特定上下文强依赖的样式,要慎重考虑是否作为块来定义。
  3. 避免深层嵌套:BEM的目的之一是提高代码的清晰和可维护性,深层次的BEM类名嵌套会违背这一原则。
  4. 一致性:在整个项目中,坚持使用BEM命名,确保团队成员都对约定保持一致的理解和执行。

使用BEM命名约定的目的是创建出可预测、可重用、并且容易理解的代码。这需要团队成员之间有良好的沟通,并且需要在项目开始时就确立清晰的命名规则。

相关问答FAQs:

问题1:CSS中的BEM命名约定是什么?
答案:BEM(块、元素、修饰符)是一种命名约定,用于在编写模块化CSS时创建清晰、可重用和可扩展的代码。BEM的核心思想是将样式分解为块(组件)、元素和修饰符。块是一个独立的、可重用的UI组件,元素是块的组成部分,修饰符用于改变块或元素的外观或状态。

问题2:如何使用BEM命名约定创建可重用的CSS代码?
答案:使用BEM命名约定创建可重用的CSS代码的关键是要遵循BEM的命名约定。首先,为你的块选择一个唯一的类名,使用连字符或下划线来分隔单词。然后,在块内部的元素上使用两个下划线连接块名和元素名。最后,使用单个下划线或连字符来分隔块名和修饰符。这种命名约定使得你的CSS代码具有清晰的结构,并且易于理解和维护。

问题3:BEM命名约定对SEO有什么影响?
答案:从SEO的角度来看,BEM命名约定并没有直接的影响。然而,使用BEM命名约定可以使你的代码更加模块化和可重用,使得页面结构更加清晰和易于理解。这可能会改善用户体验和网站性能,进而对SEO产生积极的影响。此外,通过遵循一致的命名约定,你可以更轻松地查找和修改代码,从而提高开发效率。总体而言,BEM命名约定可以为网站的可维护性和可扩展性做出贡献,这对于SEO来说是一个重要的因素。

最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

零代码低代码:《零代码与低代码的对比》
01-07 10:05
低代码市场占有率:《低代码市场占有率分析》
01-07 10:05
低代码定制开发:《低代码定制开发实践》
01-07 10:05
低代码云:《低代码云平台优势》
01-07 10:05
低代码实施:《低代码实施流程详解》
01-07 10:05
低代码开发优势:《低代码开发的多重优势》
01-07 10:05
低代码React:《低代码与React结合》
01-07 10:05
低代码数据库设计:《低代码数据库设计技巧》
01-07 10:05
低代码开发指的是:《低代码开发定义与应用》
01-07 10:05

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流