SASS是Syntactically Awesome Stylesheete
Sass的缩写,它是css的一个开发工具,提供了不少便利和简单的语法,让css看起来更像是一门语言,这种特性也被称为“css预编译”。它的主要设计思想是让咱们能够按照编程的思路编写本身的样式,而后经过“编译器”生成咱们所须要的css文件。css
固然,SASS只是css预编译工具中的一种,相似的工具还有Less、stylus等,SASS起初语法采用缩进排列形式,但对于设计师来讲既不直观还容易出现错误。在吸收了Less的一些特性基础上,SASS3.0有了大幅改进,也就是如今的SCSS。html
SASS最先来源于Haml项目,但这个工程饱受诟病,不少人认为它使html失去语义化的特性,所以,并无普遍的获得推广,而源自于它的SASS受到一致的承认,SASS基于Ruby编写,也是Ruby On Rails的主力插件。尽管如此,你无需担忧本身没有Ruby基础,你须要的只是一个Ruby环境(如今已经有人把SASS移植到python编译环境下了)。前端
注:因为国内网络缘由,可能会致使gem安装插件时失败,此时能够将gem源切换为淘宝的ruby镜像站http://ruby.taobao.org/
3. 使用
SASS文件的后缀为.scss,可使用下面的命令将scss文件编译为最终使用的css文件:java
sass demo.scss
或者指定css文件名python
sass demo.scss product.css
SASS支持变量的定义,你可使用$来定义一个变量,这样咱们就能够把一些公用的样式定义为一个变量,在使用时直接引用便可:css3
$white:#fff; $font12:12px; .menu{ color: $white; font-size: $font12; }
编译后:web
.menu { color: white; font-size: 12px; }
SASS支持两种嵌套方式:选择器嵌套和属性嵌套。嵌套极大程度上下降了选择器名称和属性的重复书写。编程
.header{ .logo{ display: block; border: none; } ul li{ line-break: normal; } }
编译后:segmentfault
.header .logo { display: block; border: none; } .header ul li { line-break: normal; }
二者对比不难发现,省去了很大一部分的选择器的层级声明。
能够经过&来表示父元素选择器,好比咱们声明一个a标签的样式:浏览器
a{ text-decoration: none; &:hover{ color: #007998; } }
编译后:
a { text-decoration: none; } a:hover { color: #007998; }
h3{ font:{ size:26px; weight:normal; family:arial } }
编译后:
h3 { font-size: 26px; font-weight: normal; font-family: arial; }
固然实际状况font定义可能更简洁些,这里只是作一个示例。
SASS中,你能够对属性值进行简单的运算, 好比:
$white:#fff; $font12:12px; .newsize{ font-size: $font12 + 2; color:$white - #007998; }
编译后生成:
.newsize { font-size: 14px; color: #ff8667; }
固然除了最基本的加减乘除运算函数,SASS还提供了不少其余有趣的函数,像咱们最经常使用的颜色函数lighten(减淡)和darken(加深)。
.lgt{ color: lighten($black,10%); background-color: darken($white,50%); }
编译后能够获得一个运算好的颜色值:
.lgt { color: #1a1a1a; background-color: gray; }
更多的函数信息,请查看SASS官方函数大全
SASS的混合是一个很是值得你去尝试的特性,若是你对这个概念不太清楚,那么你能够认为他就是一个模板的宏定义,并且这个宏还能接收参数。
@mixin box-shadow{ -webkit-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); -moz-box-shadow:inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); } .funny-box{ @include box-shadow; }
编译后:
.funny-box { -webkit-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); -moz-box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); box-shadow: inset 0px 1px 0px rgba(255, 255, 255, 0.5), 0px 1px 2px rgba(0, 0, 0, 0.15); }
带参数的mixin:
@mixin border-radius($circle:50px){ -webkit-border-radius: $circle; -moz-border-radius: $circle; border-radius: $circle; } .circle{ @include border-radius(10px); }
$circle:50px
为默认参数,能够经过传递参数来覆盖默认参数,编译后效果以下:
.circle { -webkit-border-radius: 10px; -moz-border-radius: 10px; border-radius: 10px; }
除此以外,minxin还支持多个参数,也支持相似于java中的String...类型的多个值的传递。
既然SASS看起来像一门语言了,那么其余语言的一些基本特性,也应该是其所具有的,SASS不孚众望,具有了一个简单的继承特性,使用这个特性须要关键字@extend
。
.pclass{ border: 4px solid #ff9aa9; } .subclass{ @extend .pclass; border-width: 2px; }
编译后:
.pclass, .subclass { border: 4px solid #ff9aa9; } .subclass { border-width: 2px; }
介绍完SASS的一些基本入门知识点后,你是否有想尝试下的冲动呢?工欲善其事,必先利其器;这里简单介绍下一个开发中常用的SASS工具compass,compass是SASS团队成员开发的,compass是对SASS的一个封装,目的是为开发者提供一些丰富的mixin组件以及一些实用的工具模块。compass也已经成为ruby on rails的一个标配组件。
安装依然使用ruby gem安装方式,参照前面安装sass过程,gem命令以下:
gem install compass
如今安装compass时,通常都附带安装上了sass组件,也就是说你能够跳过前面安装sass的流程了。
工程的建立
compass create yourpj;
此时会在目录下生成三个文件:
已有工程的初始化
对于已经建立好的工程,要想支持compass编译,只须要初始化一下就能够(切换到指定目录下):
compass init
编译
完成sass的开发后,只须要运行下编译命令:
compass compile
compile支持多种模式的编译,详细信息可经过compass compile -h
查看。
每次编写sass完成后,都须要手动运行下编译命令,能不能自动编译呢?那固然是能够的,只须要对当前工程添加watch监视,以下:
compass watch
组件模块
前面咱们提到compass提供了便捷的组件模块,咱们来一块儿看看有哪些经常使用的组件吧:
reset使用:
@import "compass/reset";
这样就会在css中生成重置样式了,不用咱们再本身定义重置样式了。
css3使用:
@import "compass/css3";
这是个绝对好用的特性,咱们知道因为浏览器对css3支持的差别性,咱们不少时候须要写一堆针对不一样浏览器前缀样式,着实很烦人,css3命令模块帮咱们解决了这个问题,咱们只需include相应样式定义便可,compass会自动为咱们生成针对不一样浏览器的样式定义:
@import "compass/css3"; .circle { @include border-radius(5px); }
编译后:
.circle { -moz-border-radius: 5px; -webkit-border-radius: 5px; -o-border-radius: 5px; -ms-border-radius: 5px; -khtml-border-radius: 5px; border-radius: 5px; }
就写到这吧,其余特性慢慢探讨吧!