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);
}
相关推荐
小陈工10 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao13115 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉15 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro15 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常15 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆16 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶16 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐16 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅16 小时前
Vue如何集成封装Axios
前端·javascript·vue.js
康一夏16 小时前
Next.js 13变化有多大?
前端·react·nextjs