面试官:你懂不懂BEM架构?会手写吗?

了解与编写BEM架构

1.了解BEM架构的知识

首先需要了解 BEM架构 是一个什么东西?

这个东西听起来很高大上,但是实际上你在使用 element 框架的时候就在不经意间使用到他。

首先来看一段百度的词典

BEM是一种前端命名方法论,主要是针对CSS,意思是块(Block)、元素(Element)、修饰符(Modifier)的简写。这种命名方法让CSS便于统一团队开发规范和方便维护。(baike.baidu.com/item/BEM/23...)

再来结合一下 element 框架来理解一下

在这里展示的 el-button--primary 就是包含了上述的两个要素块(Block)、修饰符(Modifier)。

在这里展示的 el-input__wrapper 就是包含了上述的两个要素块(Block)、元素(Element)。

这样子看下来是否浅显易懂了呢?

了解了这个之后,我们来手写一下这个是如何实现的。

2.编写BEM架构

2.1环境搭建

2.1.1使用vite 快速构建一个项目(这个应该不必多说)

2.1.2创建一个bem.scss文件

2.1.3使用你喜欢的构建工具 比如npm pnpm yarn等 安装一个sass

npm 复制代码
npm install -g sass

2.2书写代码

2.2.1 定义一个命名空间

在这个 vow 中 你可以任意设定你想要的值 类似于 el 的这个前缀

!default 的意思在于 假使你没有设定其他的值 那就默认使用它

ts 复制代码
$namespace:'vow' !default

2.2.2 书写后面的步骤 整体(懒得取名字了)

ts 复制代码
$namespace:'vow' !default; 
$block-sel:'-' !default;
$element-sel:'__' !default;
$modifier-sel:'--' !default;

@mixin b($block){
  $B:#{$namespace + $block-sel + $block};   
  .#{$B}{     
    @content;  
  }
}

@mixin e($el){
  $parentLevel:&;  
  @at-root{   
    #{$parentLevel + $element-sel + $el}{
      @content;
    }
  }
}

@mixin m($mod){
  $parentLevel:&;
  @at-root{
    #{$parentLevel + $modifier-sel + $mod}{
      @content;
    }
  }
}

2.3配置

他这个的使用 不是通过去引用 而是通过去配置全局 来实现让全局适配

配置项就是在 vite.config.ts 下面

3.如何使用

使用的方法如下

展示效果如下

4.基本范围

这个BEM架构 一般用于 封装组件库 或者 需要规范化的写法

当然 你要是想要写防御性代码 也不是不可以

因为肚子饿了想要去吃个饭 在 结尾的这里稍微仓促了些 嘿嘿 后面找个机会补一下

相关推荐
客场消音器7 分钟前
我用两周半 Vibe Coding 做了一个前额叶训练的微信小程序
前端·javascript·后端
铁皮饭盒1 小时前
成为AI全栈 - 第4课:Drizzle ORM SQLite Elysia 数据库实战
前端·后端
ascarl20101 小时前
Linux.do 帖子整理:AI 调用 Chrome DevTools 调试前端页面
linux·前端·人工智能
DanCheOo1 小时前
开源 | 我是怎么用 ai-memory 让 Cursor 每次开新对话都自动知道项目背景的
前端·人工智能·ai·ai编程
MPGWJPMTJT2 小时前
告别手动切换 Node 版本:从 nvm 迁移到 Volta
前端
heimeiyingwang2 小时前
【架构实战】设计一个日志分析平台(ELK架构)
elk·架构·linq
Apifox2 小时前
Apifox 近期更新|AI Agent Debugger、A2A Debugger、Postman API 导入、Ask AI 侧边栏对话
前端·人工智能·后端
嗷o嗷o2 小时前
Android 前台服务为什么越来越难用了?很多问题不是限制多,而是你任务模型就不该用 FGS
前端
摇滚侠2 小时前
软件开发外包项目组,如何提高代码质量和开发效率
java·开发语言·前端·ide·intellij-idea
企业架构师老王2 小时前
货物入库分类混乱与库位规划难题:基于实在Agent的非侵入式仓储架构演进指南
人工智能·ai·架构