SASS入门

SASS是一种对CSS进行了扩充的开发工具,它提供了许多便利的写法,使得CSS的开发变得简单和可维护,大大节省了样式设计者尤其是有编程背景的样式设计者的时间。符合SASS语法的文件就是普通的文本文件,里面可以直接使用CSS语法。SASS文件后缀名是.scss

1.变量与计算
SASS允许定义变量,变量需要冠以$前缀,如:

$period : 1s;
$effect : ease-in;
$trans_property : all;
a {
  -moz-transition:  $trans_property $period $effect;
  -webkit-transition:  $trans_property $period $effect;
  -o-transition:  $trans_property $period $effect;
  transition:  $trans_property $period $effect;
 }

经转换后的CSS代码为:

a {
  -moz-transition: all 1s ease-in;
  -webkit-transition: all 1s ease-in;
  -o-transition: all 1s ease-in;
  transition: all 1s ease-in;
}

【代码解析】从代码上看似乎使用SASS变量的源代码更长,但是有了变量遇到以后的调整变化时,就只需要在变量定义的地方变更值,而不用通过全文搜索去替换。相信有过网站维护经验的读者能够体会SASS变量的好处。这也是Ionic在定义CSS样式类使用的最常见模式。

如果变量需要镶嵌在字符串之中,就必须需要写在#{}之中,如:

$side : left;
$default_radius : 5px;
.rounded {
  border-#{$side}-radius: $default_radius;
}

经转换后的CSS代码为:

.rounded {
  border-left-radius: 5px;
}

SASS允许在代码中使用计算表达式,如:

$var : 2;
$more_px : 10px;
body {
  margin: (16px/2);
  top: 100px + 5 * $more_px;
  right: $var * 10%;
}

经转换后的CSS代码为:

body {
  margin: 8px;
  top: 150px;
  right: 20%;
}

2.样式嵌套
标准的CSS只能支持单层的选择器{}块结构,对于习惯了JavaScript开发的人来说无疑是值得改进的一个地方。而经SASS扩展,可以允许无限层的选择器嵌套,如:

$default_font_size: 100%;
.container {
  h1 {
    color:red;
    font-size: $default_font_size * 2;
  }
  h2 {
    color:blue;
    font-size: $default_font_size * 1.5;
  }
}

经转换后的CSS代码为:

.container h1 {
  color: red;
  font-size: 200%;
}
.container h2 {
  color: blue;
  font-size: 150%;
}

CSS属性名也可以嵌套生成,如:

div.container {
  border: {
    color: green;
  }
  border-left: {
    color: red;
  }
}

经转换后的CSS代码为:

div.container {
  border-color: green;
  border-left-color: red;
}

在嵌套的代码块内,可以使用&占位符表示引用父元素。如:

a {
  &:link { color: blue; }
  &:visited { color: green; }
  &:active { color: blue; }
  &:hover { 
    color: red; 
    font-weight: bold;
  }
}

经转换后的CSS代码为:

a:link {
  color: blue;
}
a:visited {
  color: green;
}
a:active {
  color: blue;
}
a:hover {
  color: red;
  font-weight: bold;
}

3.单行注释 //
SASS是CSS的超集,因此标准的CSS注释 /* comment */ ,会保留到编译后生成的文件。而为了方便开发人员的调试,SASS支持了类似JavaScript的单行注释符//,如:

/*
这是单行注释,将被保留
*/
p{
  color: red; // 单行注释示例
  font-size: 10px; /* CSS原生注释风格示例 */
}

经转换后的CSS代码为:

/*
这是单行注释,将被保留
*/
p {
  color: red;
  font-size: 10px;
  /* CSS原生注释风格示例 */
}

【代码解析】最终在生成的CSS代码里,标准的CSS注释被保留,单行注释符//被忽略省去,出于保护目的不愿把内部注释发布到网上的开发者也可以考虑使用这个方法。

4.继承@extend

SASS允许一个选择器继承另一个选择器,如:

.classParent1{
  border: 1px solid #ddd;
}
.classParent2{
  color: red;
 text-align: center;
}
.classChild {
  @extend .classParent1;
  @extend .classParent2;
  font-size:120%;
}
p {
  @extend .classParent1;
  @extend .classParent2;
  font-size:120%;
}

经转换后的CSS代码为:

.classParent1, .classChild, p {
  border: 1px solid #ddd;
}
.classParent2, .classChild, p {
  color: red;
  text-align: center;
}
.classChild {
  font-size: 120%;
}
p {
  font-size: 120%;
}

【代码解析】这里可以看到SASS跟CSS代码相比的好处是既通过@extend继承了父CSS类的样式属性,又把相关的声明都放在子CSS类或子元素声明里,这样的代码结构可阅读可维护性明显更佳。

5.混入@mixin与@include

最早的SASS是用Ruby开发的,因此该语言的作者引入了一些类似Ruby的语言结构,其中就有用于实现多重继承的混入(Mixin)。混入有点像C语言的宏,是可以定义以后在被引入的地方展开而达到重用的代码块。
首先需要使用@mixin命令,定义一个代码块,随后再使用@include命令,调用这个混入代码块使之原地展开,如:

$border-width : 1px;
@mixin left-setting {
float: left;
margin-left: 10px;
padding-left: 2px;
border-left: $border-width;
}
div {
  @include left-setting;
}

经转换后的CSS代码为:

div {
  float: left;
  margin-left: 10px;
  padding-left: 2px;
  border-left: 1px;
}

【代码解析】如代码所示,混入定义本身并不生成CSS代码,它类似于静态库被嵌入,当一个元素或者CSS类引入了多个混入代码块,则就相当于实现了多重继承的概念了。

此处变量$border-width的定义位置需要在名为left-setting的混入之前,否则将无法获取该变量的值。这种要求是SASS编译器本身的限制导致的。
混入还可以指定参数和默认值,既像C语言的宏又强于它,如:

@mixin left-setting($border-width: 3px) {
float: left;
margin-left: 10px;
padding-left: 2px;
border-left: $border-width;
}
div {
  @include left-setting;
}
div.special{
  @include left-setting(5px);
}

经转换后的CSS代码为:

div {
  float: left;
  margin-left: 10px;
  padding-left: 2px;
  border-left: 3px;
}

div.special {
  float: left;
  margin-left: 10px;
  padding-left: 2px;
  border-left: 5px;
}

【代码解析】如代码所示,生成的第一个元素在引入时使用了默认参数值,而第二个在引入时使用了指定参数值。

下为其中一小段代码片段:

// Single Corner Border Radius
@mixin border-top-left-radius($radius) {
  -webkit-border-top-left-radius: $radius;
          border-top-left-radius: $radius;
}
@mixin border-top-right-radius($radius) {
  -webkit-border-top-right-radius: $radius;
          border-top-right-radius: $radius;
}
@mixin border-bottom-right-radius($radius) {
  -webkit-border-bottom-right-radius: $radius;
          border-bottom-right-radius: $radius;
}
@mixin border-bottom-left-radius($radius) {
  -webkit-border-bottom-left-radius: $radius;
          border-bottom-left-radius: $radius;
}

【代码解析】这样为针对两种不同的浏览器分别定义元素的四个角的圆角半径提供了简单的方式。

6.颜色计算

SASS提供了一些内置的颜色函数,以便通过种子颜色生成系列颜色,这样能够节省大量的自行计算和查找调色板的时间,常见的颜色函数与使用方式如下所示。

$main_color: #336699;
$second_color: #993266;
#page1{
  //提升亮度
  color: lighten($main_color, 10%); 
}
#page2{
  //降低亮度
  color: darken($main_color, 10%); 
}
#page3{
  //提升饱和度
  color: saturate($main_color, 10%); 
}
#page4{
  //降低饱和度
  color: desaturate($main_color, 10%); 
}
#page5{
  //调整色调
  color: adjust-hue($main_color, 10%); 
}
#page6{
  //取灰度颜色
  color: grayscale($main_color); 
}
#page7{
  //混合两种颜色
  color: mix($main_color, $second_color); 
}

经转换后的CSS代码为:

#page1 {
  color: #4080bf;
}

#page2 {
  color: #264d73;
}

#page3 {
  color: #2966a3;
}

#page4 {
  color: #3d668f;
}

#page5 {
  color: #335599;
}

#page6 {
  color: #666666;
}

#page7 {
  color: #664c80;
}

【代码解析】在SASS代码里的相关位置已经对使用到的函数进行过了注释,这里不再重复说明。当需要对提供的默认颜色方案进行微调或是设计自己的APP应用的颜色方案时,读者可以考虑使用这些便捷函数。

7.引入文件@import
@import
  // Ionicons引入图标
  "ionicons/ionicons.scss",

  // Variables引入变量
  "mixins",
  "variables",

  // Base引入基础模块
  "reset",
  "scaffolding",
  "type",
……

【代码解析】请注意代码中引入文件名的区别,当SASS文件以为前缀开头时,使用@import命令不需要写出这个前缀和.scss的后缀。

8.条件语句@if和@else
@mixin flex-wrap($value: nowrap) {
  -webkit-flex-wrap: $value;
  -moz-flex-wrap: $value;
  @if $value == nowrap {
      -ms-flex-wrap: none;
  } @else {
      -ms-flex-wrap: $value;
  }
  flex-wrap: $value;
}

【代码解析】由于IE浏览器的flex-wrap属性值与其他浏览器不一样,因此代码里通过条件语句进行了额外判断。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容

  • 学习Sass(官网:Sass)之前需要了解什么是Sass,Sass全称:Syntactically Awesome...
    haoxilu阅读 491评论 0 3
  • 一、使用变量 【作用】:你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属...
    码代码的青年阅读 915评论 0 0
  • 声明变量 定义变量的语法: 在有些编程语言中(如,JavaScript)声明变量都是使用关键词“var”开头,但是...
    Junting阅读 1,470评论 0 6
  • 很详细的sass入门指南,学习一下。原文sass入门指南css预处理器已经算不上一个新鲜的词了,当前比较有代表性的...
    hzrWeber阅读 1,019评论 0 18
  • CSS预处理器,用一种专门的语言进行页面Web样式设计,编译生成正常的CSS文件以供使用,可以让CSS更加简洁、适...
    刘尐六阅读 912评论 0 0