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 命名规范!

相关推荐
小章鱼学前端4 分钟前
2025 年最新 Fabric.js 实战:一个完整可上线的图片选区标注组件(含全部源码).
前端·vue.js
ohyeah5 分钟前
JavaScript 词法作用域、作用域链与闭包:从代码看机制
前端·javascript
流星稍逝7 分钟前
手搓一个简简单单进度条
前端
倚栏听风雨29 分钟前
详解 TypeScript 中,async 和 await
前端
小皮虾37 分钟前
告别服务器!小程序纯前端“图片转 PDF”工具,隐私安全又高效
前端·javascript·微信小程序
ohyeah38 分钟前
我的变量去哪了?JS 作用域入门指南
前端·javascript
灼华_40 分钟前
Vue 3 + Vite + Router + Pinia + Element Plus + Monorepo + qiankun 构建企业级中后台前端框架
前端
倚栏听风雨42 分钟前
TypeScript 中,Promise
前端
影i1 小时前
Vue 3 踩坑实录:如何优雅地把“上古”第三方插件关进 Iframe 小黑屋
前端
小明记账簿_微信小程序1 小时前
vue项目中使用echarts做词云图
前端