Sass常用语法总结

Sass常用语法总结

类别 语法 说明 示例
变量 $变量名: 值; 存储可复用的值,如颜色、尺寸等 $primary-color: #3498db; $base-margin: 20px;
嵌套 选择器嵌套 简化CSS层级结构 nav { ul { margin: 0; } }
父选择器 & 引用父选择器 a { &:hover { color: red; } }
局部文件与导入 _文件名.scss @import 创建模块化样式文件 @import 'variables'; @import 'mixins';
混合宏 (Mixin) @mixin @include 定义可重用的样式块 @mixin flex-center { display: flex; justify-content: center; } .container { @include flex-center; }
函数 @function 自定义函数处理值 @function double($n) { @return $n * 2; } width: double(10px);
继承 @extend 共享一组CSS属性 .btn { padding: 10px; } .btn-primary { @extend .btn; background: blue; }
运算 算术运算 支持加减乘除和取余 width: 100% / 3; font-size: 12px + 2px;
控制指令 @if / @else 条件判断 @if lightness($color) > 50% { background: black; }
@for 循环生成样式 @for $i from 1 through 3 { .item-#{$i} { width: 20px * $i; } }
@each 遍历列表 @each $animal in dog, cat, bird { .#{$animal}-icon { background: url('#{$animal}.png'); } }
@while 条件循环 $i: 1; @while $i < 4 { .item-#{$i} { width: 20px * $i; } $i: $i + 1; }
插值 #{} 在属性名或选择器中插入变量 $side: top; margin-#{$side}: 10px;
颜色函数 lighten() / darken() 调整颜色亮度 lighten(#3498db, 20%) darken(#3498db, 20%)
rgba() 设置颜色透明度 rgba($primary-color, 0.5)
mix() 混合两种颜色 mix(#3498db, #e74c3c, 50%)
注释 // 注释 /* 注释 */ 单行注释(不编译到CSS) 多行注释(可编译) // 这段是单行注释 /* 这段是多行注释 */
内置函数 percentage() 转换为百分比 width: percentage(0.5); // 50%
round() / ceil() / floor() 数值取整 round(3.7) // 4 ceil(3.2) // 4 floor(3.7) // 3
模块系统 @use (推荐) 导入模块并命名空间 @use 'variables' as vars; color: vars.$primary-color;

实际开发建议

  1. 变量:用于主题色、间距、字体等设计系统值

  2. 混合宏:封装常用CSS模式(flex布局、清除浮动等)

  3. 嵌套:适度使用,避免过度嵌套导致选择器过于复杂

  4. 模块化 :使用@use替代@import(Sass新版特性)

  5. 函数:处理复杂的计算逻辑,提高代码复用性


典型项目结构

复制代码
styles/
├── abstracts/
│   ├── _variables.scss    # 变量
│   ├── _mixins.scss       # 混合宏
│   └── _functions.scss    # 函数
├── components/            # 组件样式
├── layout/               # 布局样式
├── pages/                # 页面特定样式
└── main.scss             # 主入口文件

这些语法在Vue/React项目、响应式设计、主题定制等场景中应用广泛,能显著提升CSS开发效率和维护性。

相关推荐
IT_陈寒3 分钟前
SpringBoot项目启动速度提升300%?这5个隐藏配置太关键了!
前端·人工智能·后端
小碗细面3 分钟前
5 分钟上手 Claude 自定义 Subagents
前端·人工智能·ai编程
小J听不清8 分钟前
CSS 浮动(float)全解析:布局 / 文字环绕 / 清除浮动
前端·javascript·css·html·css3
wuhen_n9 分钟前
生产环境极致优化:拆包、图片压缩、Gzip/Brotli 完全指南
前端·javascript·vue.js
用户693717500138414 分钟前
315曝光AI搜索问题:GEO技术靠内容投喂操控答案,新型营销操作全揭秘
android·前端·人工智能
周星星日记20 分钟前
pnpm为什么成为"最先进的管理包工具"
前端
多厘22 分钟前
使用 opencode 和灵感写一个 mac App (实操版)
前端·github
Wect23 分钟前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·算法·typescript
炫饭第一名25 分钟前
从前端视角解读 OpenClaw(上):Lit 驱动的 AI 控制网关面板
前端·人工智能·前端框架
掘金者阿豪26 分钟前
MiGPT GUI给小爱音箱装「AI 大脑」,自定义人设 + 百变音色!cpolar 内网穿透实验室第 726 个成功挑战
前端·后端