在前端开发中,我们经常会用到 BEM 命名规范来管理 CSS 类名。但手写 BEM 类名很繁琐,特别是当项目复杂度高时,修改 CSS 类名会变得很困难。为解决这个问题,我介绍一个 npm 包 —— bem-classnames-maker。
什么是 bem-classnames-maker
bem-classnames-maker 是一个能够自动根据 BEM 命名规范生成 CSS 类名的 npm 包。它支持多层嵌套、条件判断等功能,能够帮助我们快速、高效地生成符合 BEM 命名规范的类名。它的使用方法也很简单,我们可以通过 npm 下载并在项目中引入它来使用。
如何使用 bem-classnames-maker
- 安装 bem-classnames-maker
npm install bem-classnames-maker --save-dev
- 引入 bem-classnames-maker
const bem = require('bem-classnames-maker');
- 基本使用
bem('block'); // => 'block' bem('block', 'element'); // => 'block__element' bem('block', 'element', 'modifier'); // => 'block__element block__element--modifier' bem('block', { element: 'element', 'element--modifier': false }); // => 'block__element' bem('block', { element: 'element', 'element--modifier': true }); // => 'block__element block__element--modifier'
- 多层嵌套
bem(['block1', 'block2', 'block3']); // => 'block1 block2 block3' bem(['block1', { block2: ['element1', 'element2'] }, 'block3']); // => 'block1 block2__element1 block2__element2 block3'
- 条件判断
bem('block', { 'element--modifier': true }); // => 'block__element block__element--modifier' bem('block', { 'element--modifier': false }); // => 'block__element' bem('block', { 'element--modifier': undefined }); // => 'block__element' bem('block', { 'element--modifier': null }); // => 'block__element'
常见问题解答
- bem-classnames-maker 支持哪些参数?
bem-classnames-maker 支持三个参数:block(块)、element(元素)和 modifier(修饰符)。当你只传入 block 参数时,bem-classnames-maker 会自动将其转换为符合 BEM 命名规范的类名。当你传入 block 和 element 参数时,它们会被拼接起来形成一个 BEM 类名。当你传入 block、element 和 modifier 参数时,它们会被拼接起来形成一个 BEM 类名,其中 modifier 参数会带上两个短横线。例如:
bem('block'); // => 'block' bem('block', 'element'); // => 'block__element' bem('block', 'element', 'modifier'); // => 'block__element block__element--modifier'
- bem-classnames-maker 支持嵌套吗?
bem-classnames-maker 支持多层嵌套,你可以通过传入数组来实现。例如:
bem(['block1', { block2: 'element' }, 'block3']); // => 'block1 block2__element block3'
- bem-classnames-maker 支持条件判断吗?
bem-classnames-maker 支持条件判断,可以传入一个对象,对象的键名为 modifier,值为 true 或 false。如果值为 true,那么对应的 modifier 会被添加到 BEM 类名中。例如:
bem('block', { 'element--modifier': true }); // => 'block__element block__element--modifier'
- bem-classnames-maker 如何安装和使用?
你可以通过 npm 安装 bem-classnames-maker:
npm install bem-classnames-maker --save-dev
在项目中引入它:
const bem = require('bem-classnames-maker');
然后按照前面介绍的使用方法来使用就可以了。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/60067381890c4f727758427f