当前位置:首页 > AI技术 > 正文内容

如何优化大型的 过BEM拆分组件降低耦合案例|Duuu笔记

admin2个月前 (04-05)AI技术51

面向高级开发者的CSS指南,涵盖

BEM通过命名约束替代选择器层级依赖来降低CSS耦合。它用block__element和block--modifier等单一class锚定样式,避免嵌套选择器导致的隐式作用域问题,提升组件可移植性、可维护性与协作效率。

为什么BEM能降低大型应用的CSS耦合

BEM(Block-Element-Modifier)不是语法糖,是用命名约束替代选择器层级依赖的工程策略。大型项目里,

.header .nav .item:hover

这类嵌套选择器一旦跨组件复用,改一个样式就可能意外影响其他区域——因为它的作用域靠DOM结构隐式绑定,而非显式声明。

用BEM后,所有样式都锚定在单一class上:

header__nav-item

header__nav-item--active

。这意味着:

组件迁移时不用关心父容器class名是否匹配

删除组件HTML时,对应CSS可安全移除(无全局副作用)

多人协作时,

button--primary

button--secondary

的差异只在modifier,不会误改

button__icon

的margin逻辑

怎么写才算合规的BEM class名

常见错误是把语义当结构,比如写成

user-card__title-text

——这里

text

不是Element,而是冗余描述。BEM的Element必须是Block的**直接组成部分**,且名称要具体、不可再分。

正确写法示例:

(深入)

”;

张三

关键规则:

独响

一个轻笔记+角色扮演的app

下载

Block名用中划线分隔(

user-card

),不用下划线或驼峰

Element名用双下划线(

__name

),不嵌套多层(禁止

user-card__header__title

Modifier用双中划线(

--edit

),必须依附于Block或Element,不能单独存在

避免纯状态类名如

is-active

,优先用语义化modifier(

--active

遇到第三方组件库时BEM怎么共存

像Ant Design、Element Plus这类库默认不遵循BEM,直接覆盖其class(如

.el-button

)会破坏升级兼容性,也违背“样式归属明确”原则。

稳妥做法是封装一层Wrapper:

提交

然后只对

my-button

my-button__inner

写样式,用

!important

或更高优先级选择器强行接管内部渲染细节——但这仅限必须定制的场景。更推荐:

用库自带的theme变量(如

el-button

支持

--el-button-bg-color

CSS变量)

通过

:deep(.el-button)

(Vue SFC)或

host /deep/ .el-button

(旧版)局部穿透,但限定在单个组件内

接受库的视觉规范,把精力放在业务组件的BEM组织上

构建时如何避免BEM class名重复或过长

手写BEM容易拼错(

form__input

vs

form__input-field

),也难保证全团队统一。建议用工具链收敛:

VS Code装

BEM Helper

插件,输入

form__input

回车自动生成完整结构

PostCSS加

postcss-bem

,允许写

&__input { }

编译成真实class

Webpack/Vite中启用CSS Modules,配合

generateScopedName

button__text

转成

Button_button__text__xyz123

,彻底隔离

禁用

!important

和ID选择器——BEM本意是靠命名扁平化,不是靠权重压制

真正麻烦的从来不是命名规则本身,而是当一个

product-list__item

要同时适配PC端网格、移动端卡片、后台表格三种形态时,Modifier该拆成

--grid

/

--card

/

--table

,还是用

product-list--layout-grid

去控制子元素?这时候得看复用粒度——如果

__item

自身结构不变,就用Block级Modifier;如果

__item

里连标题位置都不同,那它早该拆成独立Block了。

相关文章

LLM介绍

。LLM 被证明在使用指令形式化描述的未见过的任务上表现良好。这意味着 LLM 能够根据任务指令执行任务,而无需事先见过具体示例,展示了其强大的泛化能力。 :小型语言模型通常难以解决涉...

Unity 机器学习 基础

ML-Agents 资产导入 Unity 场景创建 Unity 代码部分 Anaconda 执行 rollerball_config.yaml 机器学习逻辑处理...

【DL】2023年你应该知道的 10 大深度学习算法

3. 循环神经网络 (RNN) 4. 生成对抗网络 (GAN) 5. 径向基函数网络 (RBFN) 6. 多层感知器 (MLP) 7. 自组织图 (SOM)...

神经网络分类总结

从网络性能角度可分为连续型与离散型网络、确定性与随机性网络。 从网络结构角度可为前向网络与反馈网络。 从学习方式角度可分为有导师学习网络和无导师学习网络。 按连续突触性...

一文讲清神经网络、BP神经网络、深度学习的关系

人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。 大家研究着各种神经网络,研究得不亦乐乎, 来了两个家伙Romelhart 和Mcclelland,...

bp神经网络是什么网络,神经网络和bp神经网络

1、前馈神经网络:一种最简单的神经网络,各神经元分层排列。每个神经元只与前一层的神经元相连。接收前一层的输出,并输出给下一层.各层间没有反馈。 2、BP神经网络:是一种按照误差逆向传播...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。