sass笔记-3|Sass基础语法之样式复用和保持简洁

比特幽影
• 阅读 8318

上一篇详述了Sass如何嵌套、导入和注释这3个基本方式来保持条理性和可读性,这一篇更进一步地阐述sass保持样式复用和简洁的方式——混合器和选择器继承——这两种方式都能复用样式,使用它们也不难,但一定要注意什么时候该用什么。

零. 混合器——样式层上复用

当你需要一直复用大段样式的时候,可以考虑下混合器。

1. 基本用法

混合器使用@mixin标识符定义,然后通过@include引入,简单的说就是用@mixin定义一个混合器,它具有一个名字和一堆包含在花括号中的规则,用@include引入这个混合器(通过混合器的名字),混合器中的样式规则就会被提取到调用@include的地方。

此外,混合器中也可以包含CSS规则,可以包含选择器和选择器中的规则,甚至可以用父选择器标识符&

@mixin rounded-corners{
    -moz-border-radius:5px;
    -webkit-border-redius:5px;
    border-radius:5px;
}

.notice{
    background-color:green;
    border:2px solid #0a0;
    @include rounded-corners;
}

//导出的css如下
.notice{
    background-color:green;
    border:2px solid #0a0;
    -moz-border-radius:5px;
    -webkit-border-redius:5px;
    border-radius:5px;
}

2. 可以给混合器传参

混合器复用样式的时候,可以通过传参改变混合器中的具体属性值,和function很像。

混合器定义时,参数名称必须以变量名形式指定,此外,可选的是,参数可以有默认值,只需要在参数名后面以冒号:分隔后写上默认属性值,如果你了解各类编程语言函数的默认参数值,这应该不会陌生。

引入含有参数的选择器时,有两种传入参数的形式,一种是仅仅传入参数值,这要求传入参数值的顺序和混合器定义的参数顺序一致,另一种则是通过$name:value的形式指定传入参数的名字和值,这就不要求顺序。

以下代码定义了一个有3个参数的选择器来设置一个链接各个状态的颜色样式,其中常规样式的颜色$normal有一个默认值#233,另外两个参数没有默认值:

@mixin link-col($hover, $visited, $normal:#233){
    color:$normal;
    &:hover { color:$hover; }
    &:visited { color:$visited; }
}

当引入这个混合器的时候,可以有以下两种方式引入:

//可以这么引入,因为最后一个参数默认,可以不传入
a{
    @include link-col(red, gray);
}
//也可以这样,就不用管顺序
a{
    @include link-col($visited:gray, $hover:red);
}

3. 混合器的使用场景——注意和类的区别

如果发现一直在不停复用一段样式,应该考虑把这段样式构造成一个混合器,尤其是它本身可能是一组有意义的样式组合,并且考虑进参数的设置,让混合器更加智能。

判断一组选择器是否应该组合在一起组成一个混合器,一条经验法则:能否为这个混合器想出一个能概括它的好名字。如果能想出一个短名字来描述这几条样式组合的作用,那么往往能构造出一个合适的混合器。

混合器和CSS类很像,css类也可以复用样式,一段样式给一个类,然后那里需要这一段样式去修饰,就在哪里添加这个类。

区别在于,类是在HTML中运用的,混合器是在样式表中使用的。这意味着,“类”具有语义化的含义,而混合器仅仅是有关样式的,仅仅是描述展示出来是什么样子的。

能区分这两者微妙的区别,并且有意地去选择更合适的方式去复用样式,这能让你的代码保持可读性和可维护性。诚然,现在很多流行框架,依旧在用类去复用样式,但是语义和样式的解耦绝对是趋势。

一. 选择器继承——语义化关系上复用样式

刚描述完混合器和类的差别,在于“语义”和“展示样式”,又突然到了建立在语义化关系上复用样式的选择器继承,似乎有点绕,为什么不用类而要用选择器继承呢?

实际上,选择器继承最常用的场景就是和类一起工作的。

1. 基本用法

选择器继承,用@extend去继承一个选择器定义的所有样式。以下代码,.seriousError将会继承.error定义的所有样式。

.error{
    border: 1px red;
    background-color: #fdd;
}
.seriousError{
    @extend .error;
    border-width: 3px;
}

//输出的CSS代码是这样的
.error, .seriousError{
    border: 1px red;
    background-color: #fdd;
}
.seriousError{
    border-width: 3px;
}

是的,平时我们完全可以写输出的纯CSS代码,多写一个选择器名字和多写一行@extend命令,我们觉得差不多。

但是,在上面的例子中,.seriousError不仅会继承.error自身的所有样式(就像上面的那样),任何和.error有关的组合选择器样式也会被.seriousError以组合选择器的形式继承。

比如,在上面的样式代码是这样的:

.error{
    border: 1px red;
    background-color: #fdd;
}
.seriousError{
    @extend .error;
    border-width: 3px;
}
.error a{
    color:red;
    font-weight:bold;
}
h1.error{
    font-size:1.3em;
}

//输出的CSS是这样的,注意看下面的选择器
.error, .seriousError{
    border: 1px red;
    background-color: #fdd;
}
.seriousError{
    border-width: 3px;
}
.error a, .seriousError a{
    color:red;
    font-weight:bold;
}
h1.error, h1.seriousError{
    font-size:1.3em;
}

这个时候,如果我们不借助Sass的选择器继承,而用纯CSS来写,是不是就会有一些繁琐了。

我们再来想一下这几段代码的含义:我们描述了一个.error类来整体修饰错误提示都应该有的样式,然后.seriousError.error类的细化,描述了一个严重的错误应该有的进一步的样式。所以.seriousError应该有.error相关的所有样式,而这就是选择器继承帮助我们做的事。

2. 继承背后的基本实现思路

@extend背后最基本的想法是,如果.seriousError继承了.error,那么样式表中的任何一处.error选择器都会用.error, .seriousError这一选择器组进行替换和打开。

3. 继承的使用场景

继承是建立在语义化的关系上的,当一个元素拥有的类表明它是属于另一个类时(是另一个类的细化时),在这种情况下需要复用样式时使用,它的本质作用还是样式复用。

它和混合器相比,继承生成的代码量会相对较少,因为继承仅仅重复选择器,而混合器是重复一段样式。

另外,可以看到,一般它和类一起协同工作,当你在构建一些有关系的类时,在写这些具有层级关系的类的样式的时候,选择器继承可以帮你严谨地完成某些样式的复用,无论是这个选择器本身,还是隐藏在其他复杂选择器中的目标选择器。

4. 继承的高级用法

既然这被称为选择器继承,不是“类”继承,那么必然继承是可以针对类之外的选择器使用的,只是继承类是最常用的使用场景。

还有一种场景是,继承一个HTML元素的样式,如定一个.disabled类,样式修饰让它看上去像一个灰掉的链接,通过继承a这一元素实现:

.disabled{
    color: gray;
    @extend a;
}

还有一些关于复杂选择器的继承规则:

  1. 如果继承了一个复杂的选择器,那么只会继承这个复杂选择器命中的样式, 比如.seriousError @extend .important.error,那么被继承的.important.error被看做一个整体,单独的.important或者.error是不会被继承的;

  2. 如果一个选择器序列继承了另一个选择器,那么只会完全命中序列选择器的才会继承,比如(#main .seriousError) @extend .error最好不要这么做),那么前者的#main .seriousError也被看做一个整体,只有完全命中这个选择器的才会继承;

  3. 以逗号分隔的选择器序列是不能被继承的,因为这和继承其中任何一个选择器效果一样。

5. 使用继承时注意后代选择器

可以放心地继承有后代选择器修饰的选择器,但不用用后代选择器去继承别的选择器。即放心地用.serious { @extend (.main .error) },但是不要用.something .serious { @exten .error }

为什么,因为不这么做可能会导致继承迅速变复杂,sass可能会遗漏一些情况,考虑:

.foo .bar { @extend .baz; }
.bip .baz { a:b; }

当下面那条规则应用到.foo .bar时,有3种情况:

<div class="foo">
    <div class="bip">
        <div class="bar">...</div>
    </div>
</div>

<div class="bip">
    <div class="foo">
        <div class="bar">...</div>
    </div>
</div>

<div class="bip foo">
    <div class="bar">...</div>
</div>

所以sass必须要生成3种组合选择器才能覆盖这3种情况,但遗憾的是,sass并不总是会生成所有情况,另外,这样做,选择器的个数会迅速增加,所以最好的方式是不要这么用。

三. 小结

Sass保持样式复用和简洁的两个方式,一是混合器,混合器主要用于样式展示层的复用,可以给混合器传参从而在复用代码的同时保持灵活性,二是选择器继承,一般和类一起使用,主要用于建立在语义化关系上的样式复用,注意继承可能引发的问题。

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
SASS指南针
/配置sass用gulp自动编译sass变量计算功能嵌套注释代码重用继承Mixin颜色函数插入文件高级用法条件语句循环语句自定义函数/一、配置sass用gulp自动编译sassSASS是Ruby语言写的,必须安装Ruby,再安装SASS,基于g
Easter79 Easter79
3年前
stylus基础教程,stylus实例教程,stylus语法总结
stylus特点富于表现力、具有健壮性、功能丰富、动态编码不需要写CSS的冒号、分号、大括号和LESS、SASS功能类似,会这些的入手很快stylus特点安装使用stylus语法(一)选择器(二)变量(三)插值(四)运算符(五)内置函数(六)尾参数…(七)@extend继承
Wesley13 Wesley13
3年前
SASS基础
特点:1.在css基础上增加特性:变量、嵌套(nesting)、混合(@mixin)、继承(@extend);2.通过函数进行颜色值与属性值的运算;3.提供控制指令等高级功能;4.自定义输出指令;数据类型:Sass和JavaScript语言类似,也具有自己的数据类型,在Sass中包含以下几种数据类型:1\
Stella981 Stella981
3年前
CSS预编译器:Sass(入门),更快的前端开发
Sass扩展了CSS3,增加了规则、变量、混入、选择器、继承等等特性。Sass生成良好格式化的CSS代码,易于组织和维护。SASS是对CSS3(层叠样式表)的语法的一种扩充,它可以使用巢状、混入、选择子继承等功能,可以更有效有弹性的写出Stylesheet。Sass最后还是会编译出合法的CSS让浏览可以使用,也就是说它本身的语法并不太容易让浏览
Stella981 Stella981
3年前
CSS预处理器SASS用法和koala工具的使用
   最近在学习前端的时候,发现了一个SASS(CSS预处理器),感觉在前端布局写css样式来说是相当强大,效率又高,在用到SASS的时候感觉很爽。   首先说一下传统的CSS,在程序员的眼里感觉是一个很麻烦的东西,没有变量,也没有运算,还没有条件语句,感觉写的相当费事。  在人们都感觉费事的同时,真有牛人把CSS加入了编程的元素,这就是(CS
Stella981 Stella981
3年前
Sass预编译
sass基于Ruby       ruby的模块管理器叫gem 正规的安装方式是geminstallsass        调用命令  sass  sass文件  css文件webpack编译sass    需要的模块styleloader cssloader sas
Stella981 Stella981
3年前
Sass @media指令
本节我们学习Sass中的@media指令,@media指令用于设置样式规则到不同的媒体类型,这和CSS的使用规则差不多,但是它还有一点不同,就是@media指令可以嵌套在Sass选择器中。有点类似于JS冒泡功能,它会冒泡到样式表的顶层。@media指令的使用示例:.xkd{
Wesley13 Wesley13
3年前
CSS基本语法及页面引用
css基本语法及页面引用(1)css基本语法css的定义方法是:选择器{属性:值;属性:值;属性:值;}选择器是将样式和页面元素关联起来的名称,属性是希望设置的样式属性每个属性有一个或多个值。代码示例:/css注释ctrlshift"/"/d
Stella981 Stella981
3年前
Sass
嵌套规则(NestedRules)Sass允许将一套CSS样式嵌套进另一套样式中,内层的样式将它外层的选择器作为父选择器mainp{color:00ff00;width:97%;.redbox{
Stella981 Stella981
3年前
Sass的运算
本节我们学习Sass中的运算,一般的编程语法中都支持使用运算,Sass中同样可以做各种数学运算,包括最基本的加减乘除运算、变量运算、颜色运算、字符运算等。本节我们主要讲一下Sass中最基本的数学运算。加法运算加法运算是Sass中基本运算之一,在变量或者属性中都可以做加法运算。示例:$num
Wesley13 Wesley13
3年前
020_CSS3
目录如何学习CSS什么是CSS发展史快速入门css的优势三种CSS导入方式拓展:外部样式两种写法选择器基本选择器层次选择器结构伪类选择器属性选择器美化网页元素为什么要