news 2026/5/1 10:29:37

Sass常用语法总结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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开发效率和维护性。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 10:56:15

在Vue项目中使用Sass的完整指南

本文详细介绍了在Vue项目中集成Sass的完整方案。主要内容包括&#xff1a;安装sass和sass-loader依赖的步骤&#xff1b;在.vue文件中使用Sass语法的基本方法&#xff1b;针对Vue CLI和Vite项目的不同配置方式&#xff1b;全局变量和混入的配置技巧&#xff1b;项目结构建议和常…

作者头像 李华
网站建设 2026/5/1 8:28:54

CPU也能跑的深度估计方案|AI 单目深度估计 - MiDaS镜像全解析

CPU也能跑的深度估计方案&#xff5c;AI 单目深度估计 - MiDaS镜像全解析 &#x1f310; 技术背景&#xff1a;从2D图像中“看见”3D世界 在计算机视觉领域&#xff0c;单目深度估计&#xff08;Monocular Depth Estimation&#xff09;是一项极具挑战性但又极具实用价值的技…

作者头像 李华
网站建设 2026/5/1 9:30:10

磁珠不是随意画的,是‘算’出来的

一颗有三组供电&#xff08;3.3V、1.8V、1.2V&#xff09;的芯片&#xff0c;为什么给每一路电源进来都要串一颗磁珠呢&#xff1f;这个问题问得特别好&#xff0c;也比较典型。咱们硬件工程师在平时工作中&#xff0c;也经常遇到类似的场景——看到参考设计用了磁珠&#xff0…

作者头像 李华
网站建设 2026/5/1 8:17:06

ResNet18避坑指南:云端GPU免环境配置,3步出结果

ResNet18避坑指南&#xff1a;云端GPU免环境配置&#xff0c;3步出结果 引言&#xff1a;为什么你需要这篇指南 如果你正在复现论文中的ResNet18实验&#xff0c;大概率已经体会过环境配置的噩梦。CUDA版本冲突、PyTorch安装失败、依赖库缺失...这些看似简单的问题可能让你浪…

作者头像 李华
网站建设 2026/5/1 8:50:32

Qwen2.5-7B-Instruct结构化输出实践|基于vLLM+Chainlit快速部署

Qwen2.5-7B-Instruct结构化输出实践&#xff5c;基于vLLMChainlit快速部署 一、引言&#xff1a;为何需要结构化输出与高效推理&#xff1f; 随着大语言模型&#xff08;LLM&#xff09;在实际业务场景中的广泛应用&#xff0c;如何将模型生成的非结构化文本转化为可程序解析的…

作者头像 李华