1.0.1 • Published 6 years ago

@liuweigl/sass-bem v1.0.1

Weekly downloads
-
License
ISC
Repository
github
Last release
6 years ago

sass-bem

使用 sass 编写 bem 风格的css。

声明

该方案是 element-ui 框架中的,本人只是根据实践经验对此进行了一些修改。

推荐

configs

自定义可参考 sass 变量声明语法。

config含义默认值
$namespaceclass 前缀(命名空间)app
$block-separatorBlock 分隔符-
$element-separatorElement 分隔符--
$modifier-separatorModifier 分隔符__
$state-prefix状态样式前缀is-

mixins

mixin含义
bBEM 中的 Block
eBEM 中的 Element
mBEM 中的 Modifier
spec-selector用于自定义嵌套样式
when定义一个状态样式

使用

手动引入

  1. 安装:npm install sass-bem -D
  2. 使用
/* demo.scss */

@import 'sass-bem/index.scss';

@include b(demo){
  /* rules */
  @include e(tip){
      /* rules */
  }
  ...
}

webpack

在任何一个 sass 文件中都可使用 bem.scss 中的 mixin

  1. 安装:npm install sass-bem -D
  2. 安装: npm install sass-resources-loader -D
  3. 配置 sass-resources-loader:
module.exports = {
  // ....
  module: {
    rules: [
      // ....
      {
        test: /\.scss$/,
        use: [
          {
            loader: 'sass-resources-loader',
            options: {
              sourceMap: true,
              resources: [
                '~sass-bem/index.scss'
              ]
            }
          }
        ]
      }
    ],
  }
};

vue 项目: vue-demo

angular 项目 angular-demo

1.0.1

6 years ago

1.0.0

6 years ago