一、什么是SASS

SASS是一种CSS的开发工具,提供了许多便利的写法,大大节省了设计者的时间,使得CSS的开发,变得简单和可维护。

二、安装和使用

Sass依赖于ruby环境,所以装sass之前先确认装了ruby。先导官网下载个ruby。在安装的时候,请勾选Add Ruby executables to your PATH这个选项,添加环境变量,不然以后使用编译软件的时候会提示找不到ruby环境。安装好ruby后,然后安装Sass。(mac自带)

输入一下命令:

  1. gem install sass

这样,sass就可以使用了。

三、基本使用

Sass 有两种语法。 第一种被称为 SCSS (Sassy CSS),是一个 CSS3 语法的扩充版本;二种比较老的语法成为缩排语法(或者就称为 "Sass"), 提供了一种更简洁的 CSS 书写方式。使用 sass-convert 命令实现两者相互转换。本文介绍的是Scss用法。

  1. # 将 Sass 转换为 SCSS
  2. $ sass-convert style.sass style.scss
  3.  
  4. # 将 SCSS 转换为 Sass
  5. $ sass-convert style.scss style.sass

3.1 注释

SASS共有两种注释风格。标准的CSS注释 /* comment */ ,会保留到编译后的文件。单行注释 // comment,只保留在SASS源文件中,编译后被省略。在/*后面加一个感叹号,表示这是"重要注释"。即使是压缩模式编译,也会保留这行注释,通常可以用于声明版权信息。

3.2 变量

SASS可以使用变量,所有变量以$开头。如果变量需要镶嵌在字符串之中,就必须需要写在#{}之中。变量后面添加 !default ,表示该值是默认值。

  1. $left: left;
  2.  
  3. div{
  4. float: $left;
  5. margin-#{$left}: 20px;
  6. }

多个变量

多值变量分为list类型和map类型,简单来说list类型有点像js中的数组,而map类型有点像js中的对象。

  1. /* list */
  2. $linkColor: #08c # !default;//第一个值为默认值,第二个鼠标滑过值
  3. a{
  4. color:nth($linkColor,);
  5.  
  6. &:hover{
  7. color:nth($linkColor,);
  8. }
  9. }
  10.  
  11. /* map */
  12. $headings: (h1: 2em, h2: .5em, h3: .2em);
  13. @each $key, $value in $headings {
  14. #{$key} {
  15. font-size: $value;
  16. }
  17. }
  18.  
  19. 编译为:
  20. /* list */
  21. a { color: #08c; }
  22. a:hover { color: #; }
  23.  
  24. /* map */
  25. h1 { font-size: 2em; }
  26. h2 { font-size: .5em; }
  27. h3 { font-size: .2em; }

3.3 嵌套

SASS可以使用选择器嵌套。

  1. div {
  2. img{
  3. width: 50px;
  4. }
  5. }
  6.  
  7. //编译为
  8. div img{ width: 50px; }

属性也可以嵌套,比如 border-color 属性。

  1. div{
  2. border: {
  3. color: red;
  4. }
  5. }
  6.  
  7. //编译为
  8. div{ border-color: red; }

注意:border后面必须加上冒号。

在嵌套的代码块内,可以使用 & 引用父元素。比如 a:hover 伪类。

  1. a{
  2. &:hover{
  3. color: #ccc;
  4. }
  5. }
  6.  
  7. //编译为
  8. a:hover{ color: #ccc;}

3.4 @at-root

sass3.3.0中新增的功能,用来跳出选择器嵌套的。默认所有的嵌套,继承所有上级选择器,但有了这个就可以跳出所有上级选择器。适用 BEM 命名方式(如: .block 、.block__element 、.block--modifier)、@keyframe。先看如果使用嵌套写法是什么样的情况。

  1. .block {
  2. color: red;
  3. #{&}_element {
  4. color:blue;
  5. }
  6. #{&}--modifier {
  7. color: orange;
  8. }
  9. }
  10.  
  11. 编译为
  12. .block { color: red; }
  13. .block .block_element { color: blue; }
  14. .block .block--modifier { color: orange; }

明显编译出来的CSS并不是我们想要的代码。 @at-root 可以实现上面 BEM 的特性。

  1. .block {
  2. color: red;
  3. @at-root #{&}_element {
  4. color:blue;
  5. }
  6. @at-root #{&}--modifier {
  7. color: orange;
  8. }
  9. }
  10.  
  11. 编译为:
  12. .block { color: red; }
  13. .block_element { color: blue; }
  14. .block--modifier { color: orange; }

3.5 计算

SASS允许在代码中使用算式。这里就不做描述了。

四、代码重用

4.1 继承

SASS通过 @extend 命令使一个选择器class2继承另一个选择器class1

  1. .class1{
  2. width: 50px / ;
  3. height: 50px + 50px;
  4. }
  5. .class2{
  6. @extend .class1;
  7. height: 50px;
  8. }
  9.  
  10. 编译为:
  11. .class1, .class2 { width: 50px / ; height: 100px; }
  12. .class2 { height: 50px; }

编译后以群组选择器方式显示;如果选择器class2不需要选择器class1的某个属性,可添加该属性进行覆盖,并单独显示出来。(看文档的时候总是将群组选择的 “,” 看成 “.”,误认为后代选择器了,所以写出来。)

4.2 Mixin

Sass中使用 @mixin 声明混合,可以传递参数,参数名以$符号开始,多个参数以逗号分开,也可以给参数设置默认值 $opacity:50 ,如果一个参数可以有多组值,如 box-shadow、transition 等,那么参数则需要在变量后加三个点表示,如 $variables... 。使用 @mixin 命令,定义一个代码块。再使用 @include 命令,调用这个 @mixin。

  1. @mixin opacity($opacity:) {
  2. opacity: $opacity / ;
  3. filter: alpha(opacity=$opacity);
  4. }
  5. .opacity{
  6. @include opacity;
  7. }
  8. .opacity-{
  9. @include opacity();
  10. }
  11.  
  12. 编译为:
  13. .opacity { opacity: 0.5; filter: alpha(opacity=); }
  14. .opacity- { opacity: 0.8; filter: alpha(opacity=); }

4.3 函数

Sass定义了很多函数可供使用,当然你也可以自定义函数,以 @fuction 开始。实际项目中我们使用最多的应该是颜色函数,而颜色函数中又以lighten减淡和darken加深为最,其调用方法为lighten($color,$amount)darken($color,$amount),它们的第一个参数都是颜色值,第二个参数都是百分比。

  1. $color: red;
  2. @function rem($rem){
  3. @return $rem / + rem;
  4. }
  5. .box{
  6. foot-size: rem();
  7. color: lighten($color, %);
  8. }
  9.  
  10. 编译为:
  11. .box { foot-size: 2rem; color: #ff6666; }

五、高级使用

5.1 条件语句

@if可以用来判断:

  1. p {
  2. @if + == { border: 1px solid; }
  3. @if < { border: 2px dotted; }
  4. @if null { border: 3px double; }
  5. }
  6.  
  7. 编译为:
  8. p { border: 1px solid; }

@if 声明可以由几个 @else if语句,一个 @else 声明组成。

  1. $type: monster;
  2. p {
  3. @if $type == ocean {
  4. color: blue;
  5. } @else if $type == matador {
  6. color: red;
  7. } @else if $type == monster {
  8. color: green;
  9. } @else {
  10. color: black;
  11. }
  12. }
  13.  
  14. 编译为:
  15. p { color: green; }

5.2 循环语句

@for循环:from x to y: 不含y;from x through y:包含y。

  1. @for $i from to {
  2. .border-#{$i} {
  3. border: #{$i}px solid blue;
  4. }
  5. }
  6.  
  7. @for $i from through {
  8. .item-#{$i} { width: 2em * $i; }
  9. }
  10.  
  11. 编译为:
  12. .border- { border: 1px solid blue; }
  13. .border- { border: 2px solid blue; }
  14. .item- { width: 2em; }
  15. .item- { width: 4em; }
  16. .item- { width: 6em; }

@each

  1. $animal-list: puma, sea-slug, egret, salamander;
  2. @each $animal in $animal-list {
  3. .#{$animal}-icon {
  4. background-image: url('/images/#{$animal}.png');
  5. }
  6. }
  7.  
  8. 编译为:
  9. .puma-icon { background-image: url("/images/puma.png"); }
  10. .sea-slug-icon { background-image: url("/images/sea-slug.png"); }
  11. .egret-icon { background-image: url("/images/egret.png"); }
  12. .salamander-icon { background-image: url("/images/salamander.png"); }

@while

  1. $i: ;
  2. @while $i > {
  3. .item-#{$i} { width: 2em * $i; }
  4. $i: $i - ;
  5. }
  6.  
  7. 编译为:
  8. .item- { width: 12em; }
  9. .item- { width: 8em; }
  10. .item- { width: 4em; }

六、编译

在命令行中运行 Sass 进行编译,只要输入:

  1. sass input.scss output.css

命令 Sass 监视文件的改动并更新 CSS :

  1. sass --watch input.scss:output.css

如果你的目录里有很多 Sass 文件,你还可以命令 Sass 监视整个目录:

  1. sass --watch app/sass:public/stylesheets

在命令行后面添加 --style 编译格式 可以选择编译方式。

编译方式有四种:

  nested(默认):选择器与属性等单独占用一行,缩进量与 Sass 文件中一致,每行的缩进量反映了其在嵌套规则内的层数。当阅读大型 CSS 文件时,这种样式可以很容易地分析文件的主要结构;

  expanded:选择器、属性等各占用一行,属性根据选择器缩进,而选择器不做任何缩进;

  compact:每条 CSS 规则只占一行,包含其下的所有属性。嵌套过的选择器在输出时没有空行,不嵌套的选择器会输出空白行作为分隔符;

  compressed:删除所有无意义的空格、空白行、以及注释,力求将文件体积压缩到最小,同时也会做出其他调整,比如会自动替换占用空间最小的颜色表达方式。

编译错误,命令行中会报错,并提示错误代码行数。

学习资料:

  sass语法 http://www.w3cplus.com/sassguide/syntax.html

  Sass http://sass.bootcss.com/docs/sass-reference/

     http://www.ruanyifeng.com/blog/2012/06/sass.html

前端学习之路——scss篇的更多相关文章

  1. 前端学习之路——Git篇

    本文只是一个个人学习Git的笔记,如有错误的地方,还望指出,谢谢!参考资料如下: <Git教程--廖雪峰的官方网站 > bootstrap里面的--git_guide Git安装 在网上搜 ...

  2. 前端学习之路——gulp篇

    一.构建gulp环境 1.下载nodejs gulp基于node.js,要通过nodejs的npm安装gulp,所以要先安装node.js环境.(英文官网/中文官网链接). 通过cmd命令窗口确定安装 ...

  3. jQuery延迟加载(懒加载)插件 – jquery.lazyload.js-Web前端(W3Cways.com) - Web前端学习之路

    Lazy Load 是一个用 JavaScript 编写的 jQuery 插件. 它可以延迟加载长页面中的图片. 在浏览器可视区域外的图片不会被载入, 直到用户将页面滚动到它们所在的位置. 这与图片预 ...

  4. 前端学习之路-CSS介绍,Html介绍,JavaScript介绍

    CSS介绍 学前端必备掌握CSS样式,css为层叠样式表,用来定义页面的显示效果,加强用户的体验乐趣,那么如何用css到html中呢? style属性方式 利用标签中的style属性来改变显示样式 & ...

  5. STM32学习之路入门篇之指令集及cortex——m3的存储系统

    STM32学习之路入门篇之指令集及cortex——m3的存储系统 一.汇编语言基础 一).汇编语言:基本语法 1.汇编指令最典型的书写模式: 标号 操作码        操作数1, 操作数2,... ...

  6. 我的web前端自学之路-心得篇:我为什么要学习web前端?

    时光如流水,转眼间,自己已经是大三的学长了,看着一个个学弟学妹,心中有种莫名的感觉,很怀念大学的前两年时光,但也很憧憬着自己的未来,自己将要去经历很多从未经历的事.我是我们学校信科院的一名学生,在编程 ...

  7. Vue学习之路第一篇(学习准备)

    1.开发工具的选择 这个和个人的开发习惯有关,并不做强求,厉害的话用记事本也可以.但是我还是建议用人气比较高的编辑工具,毕竟功能比较全面,开发起来效率比较高. 我之前写前端一直用的是sublimete ...

  8. Day1前端学习之路——概述

    终于下定决心要好好学习前端知识了,以后会把学习过程中的一些随笔记录在这里.HTML.CSS.JavaScript这三大前端语言在大三的时候就有所接触,但是学习的不够深入,这一次希望能够坚持下去. 学习 ...

  9. web前端学习之路

    test 随着自己对于web前端知识了解的越多,越来越发现自己真的好菜 一脸茫然阶段 两年前大学接触网页设计,那时对于网页设计一窍不通,只是看了一本自己大学编的一本入门教材,我甚至不知道那些网页设计的 ...

随机推荐

  1. vue项目踩坑-引入bootstrap

    1.下载jquery; npm install jquery --save-dev 2.在webpack.base.conf.js中添加如下内容: var webpack = require('web ...

  2. Linux常见后缀缩写含义

    ctl: control rc: run control (A run-control file is a file of declarations or commands associated wi ...

  3. 『转』How to Think About Your Career

    开始工作的伊始,逐渐转载及阅读Medium上知名华裔设计师Julie Zhuo的文章,这是她在medium上的介绍:Product design VP @ Facebook. Lover of foo ...

  4. dp入门(先摆在这里,之后细细读)

    网址转载链接:  http://bbs.chinaunix.net/thread-4094539-1-1.html 动态规划:从新手到专家 Hawstein翻译 前言 我们遇到的问题中,有很大一部分可 ...

  5. Long型转换成IP段String、StringIP段转换成Long型

    /** 把long类型的Ip转为一般Ip类型:xx.xx.xx.xx * * @param ip * @return */ public static String getIpFromLong(Lon ...

  6. Settings Django Static Files

    静态文件是通过django.contrib.staticfiles来管理的. 配置Django静态文件,Djang官网静态文件配置介绍.简言之,通过以下三个步骤来配置和加载静态文件: 设置静态文件别名 ...

  7. 使用multiprocessing模块操作进程

    1.Process模块介绍 process模块是一个创建进程的模块,借助这个模块,就可以完成进程的创建. Process([group [, target [, name [, args [, kwa ...

  8. C语言 将十六进制字符串转为十六进制数 (二进制、十进制都适用)

    主要利用 long int strtol(const char *nptr,char **endptr,int base); 函数 函数说明: 参数base范围从2至36,或0.参数base代表采用的 ...

  9. 优化报表系统结构之报表server计算

    在报表项目中,经常会碰到数据库压力非常大影响整个系统性能的问题.由以下的传统方案的结构示意图能够看出.所有数据存储和源数据计算都放在数据库完毕.当并发訪问量较大的时候,尽管每一个报表的数据量不大,还是 ...

  10. 改动android 系统时间

    命令如 date -s "yyyymmdd.[[[hh]mm]ss]" 直接在CRT上执行,举例:date -s "20120801.120503" 但在adb ...