SCSS 中的 @mixin 指令允许定义可以在整个样式表中重复使用的样式,而 @include 指令用于将这些混入(mixin)引入到文档中。
@mixin important-text {
color: red;
font-size: 25px;
font-weight: bold;
border: 1px solid blue;
}
.danger {
@include important-text;
background-color: green;
}
上述代码中,.danger 类将包含 important-text 混入定义的所有样式属性。转换为 CSS 后,.danger 类将具有红色文本、25px 字体大小、粗体字重和蓝色边框,以及绿色背景色。
参数化混入
混入还可以接收参数,使得每次调用时都可以定制其行为。例如,创建一个接收颜色和宽度参数的边框混入:
@mixin bordered($color, $width) {
border: $width solid $color;
}
.myArticle {
@include bordered(blue, 1px);
}
.myNotes {
@include bordered(red, 2px);
}
在上面的例子中,.myArticle 和 .myNotes 类将分别具有蓝色和红色边框。
可变参数
当不确定混入或函数会使用多少个参数时,可以使用 ... 来设置可变参数。例如,创建一个盒子阴影的混入可能需要接受任意数量的阴影值作为参数:
@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);
}
在这个例子中,.shadows 类将具有两个不同的阴影效果。
浏览器前缀和混入
使用混入来处理浏览器前缀也非常方便。例如,创建一个用于变换属性的混入:
@mixin transform($property) {
-webkit-transform: $property;
-ms-transform: $property;
transform: $property;
}
.myBox {
@include transform(rotate(20deg));
}
转换为 CSS 后,.myBox 类将具有适用于不同浏览器的旋转变换样式。
通过这些示例,可以看出 SCSS 的混入和包含功能如何简化和优化样式表的编写,使得代码更加干净、可维护,并且易于重用。
补充:%
%container {
@include container;
@include grid-background;
}
'%container' 是什么意思?'%' 是干什么用的?
占位符选择器:%
Sass 支持一种特殊类型的选择器,称为"占位符选择器"。这些看起来像 class 和 id 选择器,除了 # 或 . 替换为 %。它们旨在与@extend 指令一起使用;
@extend:在某个class类中使用表示继承xx类的样式
例如:@extend %box
在不使用任何@extend 的情况下,使用占位符选择器的规则集将不会被呈现给 CSS。(即:占位符选择器有一个额外的属性,它们不会显示在生成的 CSS 中,只有扩展它们的选择器才会包含在输出中。)
%是一个占位符选择器。它自己不做任何事情,但可以扩展,就像抽象基类一样。
SCSS 语法:
%toolbelt {
box-sizing: border-box;
border-top: 1px rgba(#000, .12) solid;
padding: 16px 0;
width: 100%;
&:hover { border: 2px rgba(#000, .5) solid; }
}
.action-buttons {
@extend %toolbelt;
color: #4285f4;
}
.reset-buttons {
@extend %toolbelt;
color: #cddc39;
}
CSS 输出:
.action-buttons, .reset-buttons {
box-sizing: border-box;
border-top: 1px rgba(0, 0, 0, 0.12) solid;
padding: 16px 0;
width: 100%;
}
.action-buttons:hover, .reset-buttons:hover {
border: 2px rgba(0, 0, 0, 0.5) solid;
}
.action-buttons {
color: #4285f4;
}
.reset-buttons {
color: #cddc39;
}
简单抽象对比示例:
