scss(sass)中 & 的使用说明

在 SCSS(Sass)中,& 符号是一个父选择器引用,它代表当前嵌套规则的外层选择器。主要用途如下:


1. 连接伪类/伪元素

scss

复制

下载

复制代码
.button {
  background: blue;
  &:hover {  // 相当于 .button:hover
    background: darkblue;
  }
  &::after { // 相当于 .button::after
    content: ">";
  }
}

编译结果:

css

复制

下载

复制代码
.button {
  background: blue;
}
.button:hover {
  background: darkblue;
}
.button::after {
  content: ">";
}

2. 串联选择器(BEM 风格命名)

scss

复制

下载

复制代码
.menu {
  &__item {   // 相当于 .menu__item
    color: red;
  }
  &--dark {   // 相当于 .menu--dark
    background: black;
  }
}

编译结果:

css

复制

下载

复制代码
.menu__item {
  color: red;
}
.menu--dark {
  background: black;
}

3. 嵌套上下文

scss

复制

下载

复制代码
.page {
  .dark-theme & { // 相当于 .dark-theme .page
    background: #333;
  }
}

编译结果:

css

复制

下载

复制代码
.dark-theme .page {
  background: #333;
}

4. 避免重复书写父选择器

scss

复制

下载

复制代码
.card {
  &-header { ... }  // .card-header
  &-body { ... }    // .card-body
  &-footer { ... }  // .card-footer
}

⚠️ 注意事项

  • & 必须写在选择器开头&hover(错误)❌ → &:hover(正确)✅

  • 深层嵌套时& 会引用完整的选择器链:

    scss

    复制

    下载

    复制代码
    .a {
      .b & { // 编译为 .b .a
      }
    }

总结

场景 示例 编译结果
伪类 &:hover .parent:hover
BEM 命名 &__item .parent__item
修改上下文 .context & .context .parent
简化重复前缀 &-suffix .parent-suffix

合理使用 & 能让 SCSS 代码更简洁、可读性更强,特别适合组件化开发和 BEM 命名规范!

相关推荐
DarkLONGLOVE2 小时前
手把手教你玩转Vue组件:创建、注册、使用三步曲!
前端·javascript·vue.js
李剑一2 小时前
uni-app实现leaflet地图图标旋转
前端·trae
风度前端2 小时前
npm 2026安全新规下的免登录发包策略
前端
冴羽3 小时前
2026 年前端必须掌握的 4 个 CSS 新特性!
前端·javascript·css
rgeshfgreh3 小时前
Python流程控制:从条件到循环实战
前端·数据库·python
狗头大军之江苏分军3 小时前
告别旧生态:Ant Design 6 不再支持 IE 与现代前端趋势解读
前端·javascript·后端
C_心欲无痕3 小时前
nginx - 开启 gzip 压缩
运维·前端·nginx
闲云一鹤3 小时前
2026 最新 ComfyUI 教程 - 本地部署 AI 生图模型 - Z-Image-Turbo
前端·人工智能·ai编程
开开心心_Every3 小时前
安卓后台录像APP:息屏录存片段,行车用
java·服务器·前端·学习·eclipse·edge·powerpoint
狗头大军之江苏分军3 小时前
Ant Design 6.0 正式发布:从 V5 到 V6 有哪些变化?
前端