安装
npm install -g sass
1、Sass 变量使用 $ 符号:
$variablename: value;
$Width: 680px; body { width: $Width; }
2、Sass 嵌套规则与属性
嵌套规则
如下我们嵌套一个导航栏的样式:
Sass 代码:
nav { ul { margin: 0; padding: 0; list-style: none; } li { display: inline-block; } a { display: block; padding: 6px 12px; text-decoration: none; } }
将以上代码转换为 CSS 代码,如下所示:
Css 代码:
nav ul { margin: 0; padding: 0; list-style: none; } nav li { display: inline-block; } nav a { display: block; padding: 6px 12px; text-decoration: none; }
嵌套属性
很多 CSS 属性都有同样的前缀,例如:font-family
, font-size
和 font-weight
, text-align
, text-transform
和 text-overflow
。
在 Sass 中,我们可以使用嵌套属性来编写它们:
Sass 代码: font: { family: Helvetica, sans-serif; size: 18px; weight: bold; } text: { align: center; transform: lowercase; overflow: hidden; }
将以上代码转换为 CSS 代码,如下所示:
Css 代码:
font-family: Helvetica, sans-serif; font-size: 18px; font-weight: bold; text-align: center; text-transform: lowercase; text-overflow: hidden;
3、 @import
Sass 可以让我们减少可以帮助我们减少 CSS 重复的代码,节省开发时间。
Sass @import 指令语法如下:
@import filename;
4、@mixin 与 @include
Sass 代码:
@mixin important-text { color: red; font-size: 25px; font-weight: bold; border: 1px solid blue; } .danger { @include important-text; background-color: green; }
将以上代码转换为 CSS 代码,如下所示:
Css 代码:
.danger { color: red; font-size: 25px; font-weight: bold; border: 1px solid blue; background-color: green; }
混入中也可以包含混入,如下所示:实例
@mixin special-text { @include important-text; @include link; @include special-border; }
混入可以接收参数。
实例
/* 混入接收两个参数 */ @mixin bordered($color, $width) { border: $width solid $color; } .my { @include bordered(blue, 1px); // 调用混入,并传递两个参数 }
将以上代码转换为 CSS 代码,如下所示:
Css 代码:
border: 1px solid blue; } .myNotes { border: 2px solid red; }
混入的参数也可以定义默认值,语法格式如下:
实例
@mixin sexy-border($color, $width: 1in) { border: { color: $color; width: $width; style: dashed; } } p { @include sexy-border(blue); } h1 { @include sexy-border(blue, 2in); }
可变参数
有时,不能确定一个混入(mixin)或者一个函数(function)使用多少个参数,这时我们就可以使用 ... 来设置可变参数。
例如,用于创建盒子阴影(box-shadow)的一个混入(mixin)可以采取任何数量的 box-shadow 作为参数。
实例
@mixin box-shadow($shadows...) { -moz-box-shadow: $shadows; -webkit-box-shadow: $shadows; box-shadow: $shadows; } .shadows { @include box-shadow(0px 4px 5px #666, 2px 6px 10px #999); }
浏览器前缀使用混入
浏览器前缀使用混入也是非常方便的,如下实例:
实例
@mixin transform($property) { -webkit-transform: $property; -ms-transform: $property; transform: $property; } .myBox { @include transform(rotate(20deg)); }
将以上代码转换为 CSS 代码,如下所示:
Css 代码:
.myBox { -webkit-transform: rotate(20deg); -ms-transform: rotate(20deg); transform: rotate(20deg); }
5、@extend 与 继承
@extend 指令告诉 Sass 一个选择器的样式从另一选择器继承。
如果一个样式与另外一个样式几乎相同,只有少量的区别,则使用 @extend 就显得很有用。
以下 Sass 实例中,我们创建了一个基本的按钮样式 .button-basic,接着我们定义了两个按钮样式 .button-report 与 .button-submit,它们都继承了 .button-basic ,它们主要区别在于背景颜色与字体颜色,其他的样式都是一样的。
Sass 代码:
.button-basic { border: none; padding: 15px 30px; text-align: center; font-size: 16px; cursor: pointer; } .button-report { @extend .button-basic; background-color: red; } .button-submit { @extend .button-basic; background-color: green; color: white; }
将以上代码转换为 CSS 代码,如下所示:
Css 代码:
.button-basic, .button-report, .button-submit { border: none; padding: 15px 30px; text-align: center; font-size: 16px; cursor: pointer; } .button-report { background-color: red; } .button-submit { background-color: green; color: white; }
使用 @extend 后,我们在 HTML 按钮标签中就不需要指定多个类 class="button-basic button-report" ,只需要设置 class="button-report" 类就好了。
@extend 很好的体现了代码的复用。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)