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开发效率和维护性。

相关推荐
Hello--_--World6 分钟前
VUE:逻辑复用
前端·javascript·vue.js
陶甜也22 分钟前
3D智慧城市:blender建模、骨骼、动画、VUE、threeJs引入渲染,飞行视角,涟漪、人物行走
前端·3d·vue·blender·threejs·模型
患得患失94927 分钟前
【前端websocket】企业级功能清单
前端·websocket·网络协议
落魄江湖行27 分钟前
基础篇四 Nuxt4 全局样式与 CSS 模块
前端·css·typescript·nuxt4
禅思院28 分钟前
前端性能优化:从"术"到"道"的完整修炼指南
前端·架构·前端框架
架构师老Y2 小时前
003、Python Web框架深度对比:Django vs Flask vs FastAPI
前端·python·django
小陈工4 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao1319 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉9 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro9 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm