前端工程Bem架构及其封装


这是我学习记录的笔记,如有不正,欢迎补充

简介

首先认识一下什么是bem架构?BEM的意思就是块(block)、元素(element)、修饰符(modifier),是由Yandex团队提出的一种前端命名方法论。这种巧妙的命名方法让你的CSS类对其他开发者来说更加透明而且更有意义。BEM命名约定更加严格,而且包含更多的信息,它们用于一个团队开发一个耗时的大项目。

语法

在这里插入图片描述
看一下其中的class类,el-divider el-divider–horizontal m-0
这里加入一个类el-divider__inner

  • el表示namespace(命名空间)
  • -()表示block(块)
  • __()双下划线表示element(元素)
  • -- 双-号表示modidier(修饰符)

在vue3项目中引用

sass

在引用之前需要先了解一下sass
这里我就不具体讲解了,我把必要的了解说一下:

  1. 嵌套规则 (Nested Rules)
  2. 父选择器 &
  3. 变量 $
  4. @at-root
  5. 占位符#{}
  6. 定义混合指令 @mixin
  7. 引用混合样式 @include
    这些可以在官方文档中查看,我想只要学过css,入门sass也是喝喝水了。

创建bem.scss文件

这里面写我们的bem架构规则。

//注意:这里的xm是自定义的namespace
$namespace: "xm" !default;
$block-sel: "-" !default;
$elem-sel: "__" !default;
$mod-sel: "--" !default;

@mixin b($block) {
  $B: #{$namespace + $block-sel + $block};
  .#{$B} {
    //占位符,替代编写的css样式
    @content;
  }
}

@mixin e($elem) {
  $seletor: &;
  $E: #{$seletor + $elem-sel + $elem};
  @at-root {
    //跳出父级作用域
    #{$E} {
      //占位符,替代编写的css样式
      @content;
    }
  }
}

@mixin m($modifier) {
  $seletor: &;
  $M: #{$seletor + $mod-sel + $modifier};
  @at-root {
    #{$M} {
        //占位符,替代编写的css样式
        @content;
      } 
  } 
}

这个文件可以直接引用到项目中,改一下命名空间就行。

修改vite.config.ts

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  css: {
    preprocessorOptions: {
      scss: {
      //bem文件的位置
        additionalData: `@import "./src/bem.scss";`
      }
    }
  }
})

vue文件中使用

<template>
	<div class="xm-test">gunala
        <button class="xm-test--success">成功</button>
    </div>
</template>

//标注lang = "scss"
  <style lang="scss">
  //test是b的参数,表示拿到xm-test类
  @include b(test){
    color:red;
    //嵌套
    //success是m的参数,表示拿到的是xm-test--success
    @include m(success){
        color: green;
    }
  }
  </style>

结果

在这里插入图片描述

  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Gunalaer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值