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);
}
相关推荐
云飞云共享云桌面14 小时前
传统工作站 vs 云飞云共享云桌面:制造业设计云桌面选型深度对比
运维·服务器·前端·网络·3d·架构·制造
UXbot15 小时前
如何选择适合公司项目的UI设计工具?企业选型指南
前端·低代码·ui·团队开发·原型模式·设计规范·web app
llz_11215 小时前
web-第四次课后作业
前端·spring boot·web
武清伯MVP16 小时前
前端跨域方案大合集
前端·javascript
小刘|16 小时前
Spring AI Alibaba 集成和风天气 API 实战
java·服务器·前端
星星在线17 小时前
我是怎么把页面图片流量砍掉一半的
前端·javascript
木叶子---18 小时前
前端打包出错
前端·人工智能·tensorflow
JAVA面经实录91718 小时前
前端系统化学习计划表(含完整知识思维导图)
前端·学习
本末倒置18318 小时前
开发了一个所见所得的md编辑器,致敬Typora大佬
前端
kyriewen18 小时前
TypeScript 高级类型:我用 infer 写了一个类型安全的 EventBus,终于搞懂了泛型约束
前端·javascript·typescript