SASS的@规则

1,@import

sass扩展了import导入,对于css,@import导入在页面加载的时候去下载导入的外部文件,而sass的导入,在编译成css文件的时候就将外部的sass文件导入合并编译成一个css文件。

他支持同时导入多个文件;支持在嵌套样式中导入文件。

css 复制代码
// 顶部导入文件
<style lang="scss">
    @import './common.scss';
    @import './mixin.scss', './index.scss'; // 导入多个文件
</style>


//card.scss文件
div {
    border-radius: 6px;
}
// 嵌套中导入文件
.card {
    @import './card.scss';
}

// 编译后为
.card div {
    border-radius: 6px;
}

2,@media

sass中的media与css中的作用一样,只是sass中支持在嵌套中使用。

css 复制代码
.menu {
    width: 300px;
    @media screen and (orientation: landscape) {
        width: 400px;
    }
}

3,@if、@else if、@else

逻辑控制,与js中的if、else语法用法一致。可以配合sass中的not、and、or等字符使用

css 复制代码
$width: 100px;

@if $width == 100px {
    border-color: blue;
} @else {
    border-color: #F3F3F3;
}

@if $height > 2 {
    margin: 20px;
}

4,@for

for循环,用来迭代,限制循环的次数。不同于js的是,索引从1开始。

语法1:@for $i from <start> to <end>(不包含最后end的值)

语法2:@for $i from <start> through <end>(包含最后end的值)

css 复制代码
// 循环3次
@for $i from 1 through 3 {
    .list-#{$1} {
        width: 10px;
    }
}

// 编译后
.list-1 {
    width: 10px;
}
.list-2 {
    width: 10px;
}
.list-3 {
    width: 10px;
}

5,@each

类似于js中的foreach。sass中的each用来遍历list或者map。

语法:@each $var in <list>

css 复制代码
$widths: 2px 3px 4px; // 数组

@each $item in $widths {
    .wd-#{$item} {
        width: $item;
    }
}

// 编译后
.wd-2px {
    width: 2px;
}
.wd-3px {
    width: 3px;
}
.wd-4px {
    width: 4px;
}

6,@while

与js的while循环类似。很少使用

css 复制代码
$i: 3;

@while $i > 1 {
    .item-#{$i} {
        height: $i + px;
    }
    $i: $i - 1; // 在这里重新赋值
}

// 编译后
.item-3 {
    height: 3px;
}
.item-2 {
    height: 2px;
}
.item-1 {
    height: 1px;
}

7,@function

函数,与mixin类似,也支持可变参数与默认值。用法与js中基本类似,也支持@return返回值。

语法:@function <name>(<arguments...>)

css 复制代码
@function add($param1, $baseNo: 10px) {
    $result: $param1 + $baseNo;
    @return $result;
}

8,@use

与@important作用一样,导入外部文件,但是@use还有额外的作用,在引入时用as关键字定义定义命名空间,并可以通过命名空间调用外部文件的样式

css 复制代码
@use './common.scss' as common; // 定义命名空间common

div {
    @include common.scrollbar; // 通过命名空间属性调用外部样式
}

9,@at-root

将嵌套中的样式置顶到根部,脱离嵌套的样式层级。

css 复制代码
.main {
    @at-root .header { // 将header选择器置顶
        height: 40px;
    }
    .body {
        height: 1000px;
    }
}

// 编译后
.header {
    height: 40px;
}
.main {
    .body {
        height: 1000px;
    }
}

10,@debug、@error、@warn

sass中的@debug、@error、@warn用来打印一些信息,分别和js中的console.log()、console.error()、console.warn()类似。

css 复制代码
@if $width < 100 {
    padding-top: 20px;
} @else {
    @warn '宽度输入过大';
}

11,@extend和占位符选择器%

已了解到@extend是用来继承样式的。而占位符选择器placeholder selector是sass提供的新选择器。定义方式与ID选择器、class选择器类似,只是标识符是%。但是他只能通过@extend引用。

他的特点是,如果只定义,但是没引用,是不会编译到css文件中的

css 复制代码
// 定义占位符选择器
%eclipse {
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: no-wrap;
}

// 引用
.main {
    @extend %eclipse;
}

12,其他规则

还有一些其他常用规则,例如@mixin、@include等

相关推荐
lang201509289 分钟前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC1 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务2 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
嘿起屁儿整2 小时前
面试点(网络层面)
前端·网络
VT.馒头2 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
phltxy3 小时前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
Byron07074 小时前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js
css趣多多4 小时前
地图快速上手
前端
zhengfei6114 小时前
面向攻击性安全专业人员的一体化浏览器扩展程序[特殊字符]
前端·chrome·safari
码丁_1175 小时前
为什么前端需要做优化?
前端