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 分钟前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3601 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库
之歆1 小时前
Day07_CSS盒子模型 · 样式继承 · 用户代理样式
前端·css
DanCheOo1 小时前
AI 应用的安全架构:Prompt 注入、数据泄露、权限边界
前端·人工智能·prompt·安全架构
We་ct2 小时前
深度剖析浏览器跨域问题
开发语言·前端·浏览器·跨域·cors·同源·浏览器跨域
weixin_427771613 小时前
前端调试隐藏元素
前端
爱上好庆祝4 小时前
学习js的第五天
前端·css·学习·html·css3·js
C澒4 小时前
IntelliPro 产研协作平台:基于 AI Agent 的低代码智能化配置方案设计与实现
前端·低代码·ai编程
一袋米扛几楼984 小时前
【Git】规范化协作:详解 GitHub 工作流中的 Issue、Branch 与 Pull Request 最佳实践
前端·git·github·issue
网络点点滴4 小时前
前端与后端的区别与联系
前端