BEM规范

类型 模式 示例 说明
.block .menu 独立组件
元素 .block__element .menu__item 块的组成部分
修饰符 .block--modifier .menu--dark 块的状态/变体
带修饰符的元素 .block__element--modifier .menu__item--active 元素的状态/变体
比如:
css 复制代码
z-button__element--disabled /*z-button"组件中的某个元素(element)在禁用状态下的样式*/

带 State 的 BEM 命名规范:

通常是动态的

css 复制代码
.block[__element][--modifier][.is|has-state] 
/*eg:*/
<ul class="nav__dropdown is-open">

最佳实践

ts 复制代码
function __bem(
  prefixName: string,
  blockSuffix: string,
  element: string,
  modifier: string
) {
  let className = prefixName;

  if (blockSuffix) {
    className += `-${blockSuffix}`;
  }

  if (element) {
    className += `__${element}`;
  }

  if (modifier) {
    className += `--${modifier}`;
  }

  return className;
}

function createBEM(prefixName: string) {
  const b = (blockSuffix: string = "") =>
    __bem(prefixName, blockSuffix, "", "");
  const e = (element: string = "") =>
    element ? __bem(prefixName, "", element, "") : "";
  const m = (modifier: string = "") =>
    modifier ? __bem(prefixName, "", "", modifier) : "";
  const be = (blockSuffix: string, element: string) =>
    blockSuffix && element ? __bem(prefixName, blockSuffix, element, "") : "";
  const bm = (blockSuffix: string, modifier: string) =>
    blockSuffix && modifier ? __bem(prefixName, blockSuffix, "", modifier) : "";
  const em = (element: string, modifier: string) =>
    element && modifier ? __bem(prefixName, "", element, modifier) : "";
  const bem = (blockSuffix: string = '', element: string = '', modifier: string = '') =>
    blockSuffix && element && modifier
      ? __bem(prefixName, blockSuffix, element, modifier)
      : "";
  const is = (name: string,state: any) => (state ? `is-${name}` : ``);

  return {
    b,
    e,
    m,
    be,
    bm,
    em,
    bem,
    is
  };
}

export function createNamespace(name: string) {
  const prefixName = `z-${name}`;
  return createBEM(prefixName);
}
相关推荐
脩衜者3 分钟前
极其灵活且敏捷的WPF组态控件ConPipe 2026
前端·物联网·ui·wpf
Mike_jia8 分钟前
Dockge:轻量开源的 Docker 编排革命,让容器管理回归优雅
前端
GISer_Jing15 分钟前
前端GEO优化:AI时代的SEO新战场
前端·人工智能
没想好d17 分钟前
通用管理后台组件库-4-消息组件开发
前端
文艺理科生19 分钟前
Google A2UI 解读:当 AI 不再只是陪聊,而是开始画界面
前端·vue.js·人工智能
晴栀ay21 分钟前
React性能优化三剑客:useMemo、memo与useCallback
前端·javascript·react.js
JS_GGbond21 分钟前
JavaScript继承大冒险:从“原型江湖”到“class殿堂”
前端
XiaoYu200221 分钟前
第6章 Postgres数据库安装
前端·postgresql
洛卡卡了22 分钟前
从活动编排到积分系统:事件驱动在业务系统中的一次延伸
前端·后端·面试
知其然亦知其所以然23 分钟前
别再死记硬背了,一篇文章搞懂 JS 乘性操作符
前端·javascript·程序员