一、什么是SASS

SASS是一中CSS的开发工具,提供了许多便利的写法,大大节约了设计者们的时间,使得CSS的开发,变得简单和可维护。本文总结了SASS的主要方法。我们的目标是,有了这篇文章,日常的一般使用就不需要看官方文档了。

二、安装和使用

2.1  安装

SASS是Ruby语言写的,但是两者的语法没有关系。不懂Ruby,照样使用,只需先安装Ruby,在安装SASS,假设你已经安装RUby,接着命令行输入下面的命令:

gem  insrall  sass

然后就可以使用了。

2.2使用

SASS文件就是普通的文本文件,里面可以直接使用CSS语法。后缀名是.Scss,意思是Sassy CSS。下面的命令,可以在屏幕上显示.scss文件转化为css的代码。(假设文件名为test)

sass  test.scss

如果要将显示结果保存文件,后面再跟一个.css文件名。

sass  test.scss test.css

SASS提供四个编程风格的选项

*nested:嵌套缩进的css代码,他是默认值。

*expanded:没有缩进的,扩展的css代码。

*compact:简洁格式的css代码。

*compressed:压缩后的css代码

生产环境当中,一般使用最后一个选项

sass  ---style commpressed test.sass test.css

他也可以让SASS监听某个文件或目录,一旦文件有变动,就自动生成编译后的版本。

//watch a file

sass  --watch input.scss

//watch a directory

sass --watch app/sass:public/stylesheets

SASS的官方网站,提供了一个在线转换器,你可以在那里运行下面的各种例子

三、基本用法

3.1变量

SASS允许使用变量,所以变量用$开头。

$blue : #1875e7;

div{

color :$blue

}

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

$side : left;

.rounded{

border-#{side}-radius:5px;

}

3.2 计算功能

SASS允许在代码中使用算式

Body{

margin : (14px/2);

top : 50px + 100px;

right : $var * 10%;

}

3.3嵌套

SASS允许选择器嵌套。比如下面的CSS代码

div h1{

color : red;

}

可以写成

div{

Hi{

color : red;

}

}

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

p{

border:{

color:red;

}

}

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

在嵌套代码内,可以使用&引用父元素。比如border-color属性,可以写成:

a{

&:hover{ color :#ffb3ff; }

}

3.4注释

SASS共有两种注释风格。

标准的CSS注释/* comment */,会保留编译后的文件。

单行注释//comment,只保留在SASS源文件中,编译后被省略。

在/*后面加一个感叹号,”表示这种是重要注释”,即使是压缩模式编译,也会保留这行注释 ,通常可以用于声明版权信息。

/*!

重要注释

*/

四、代码的重用

4.1 继承

SASS允许一个选择器,比如另有一个选择器,比如现有class1:

.class1{

border:1px solid #ddd;

}

class2要继承class1,就要使用@extend命令:

.class{

@extend.class1;

font-size:120%;

}

4.2 Mixin

Mixin有点像C语言的宏(macro),是可以重用的代码块。

使用@mixin命令,定义一个代码块。

@mixin left{

float:left;

margin-left:10px

}

使用@include命令,调用这个mixin

div{

@include left;

}

mixin的强大之处,在于可以指定参数和缺省值。

@mimin left($value:10px){

float:left;

Margin-right:$value

}

使用的时候,根据需要加入参数

div{

@include left(20px);

}

下面是一个mixin的实例,用来生成浏览器前缀。

@mixin rounded($vert,$horz,$radius:10px){

border-#{$vert}-#{$horz}-radius:$radius;

-moz-border-radius-#{$vert}#{$horz}:$radius;

-webkit-border-#{$vert}-#{$horz}-radius:$radius;

}

使用的时候,可以像下面这样调用

#navbar li{ @include rounded(top,left);}

#footer{ @include rounded(top,left,5px);}

4.3颜色函数

SASS提供了一些内置函数,以便生成系列颜色。

lighten(#cc3,10%)//#d6d65c

darken(#cc3,10%)//#a3a329

grayscale(#cc3)//#808080

complement(#cc3)//#33c

4.4插入文件

@import 命令,用来插入外部文件。

@import “path/filename.scss”;

如果插入的是.css文件,则等同于css的import命令。

@import “foo.css”;

五、高级用法

5.1 条件语句

@if可以用来判断;

p{

@if 1+1 ==2{border:1px solid ;}

@if 5< 3{border:2px dotted;}

}

配套的还有@else命令:

@if lightness($color)>30%{

}@else{

}

5.2循环语句

SASS支持for循环:

@for $i from 1 to 10 {

.border-#{$i}{

Border:#{$i}px solid blue;

}

}

也支持while循环:

$i:6;

@while $i >0{

.item-#{$i}{width:2em *$i}

$i:$i-2

}

each命令,作用与for类似:

@each $member in a,b,c,d{

.#{$member}{

Background-image:url(“image/#{$member}.jpg”);

}

}

5.3自定义函数

SASS允许用户编写自己的函数。

@function double($n){

@return $n*2;

}

#sidebar{

Width:double(5px);

}

Sass学习日志的更多相关文章

  1. GRE学习日志

    发现开博客园真的很有督促作用,今天也顺便开个GRE学习日志吧 2015-02-09:单词 2015-02-10:单词 2015-02-11:单词 2015-03-02:阅读 2015-03-04:阅读 ...

  2. Cortex-M3学习日志(六) -- ADC实验

    上一次简单的总结了一下DAC方面的知识,好吧,这次再来总结一下ADC方面的东东.ADC即Analog-to-Digital Converter的缩写,指模/数转换器或者模拟/数字转换器.现实世界是由模 ...

  3. Cortex-M3学习日志(五) -- DAC实验

    终于逮了个忙里偷闲的机会,就再学一下LPC1768的外围功能吧,循序渐进是学习的基本规则,也许LPC1768的DAC与8位单片机16位单片机里面集成的DAC操作类似,但是既然这是懒猫的学习日志,就顺便 ...

  4. Sass学习笔记(补充)

    阅读目录 1. Sass和SCSS的区别 2. @while循环 3. @at-root 4. @content 5. 凸显注释 6. CSS输出样式 7. 重置浏览器样式 8. Sass调试和@de ...

  5. webpack2学习日志

    webpack说容易也容易,说难也难,主要还是看个人,想学到什么样的程度,很多公司可能要求仅仅是会用就行,但是也有一些公司要求比较高,要懂一些底层的原理,所以还是要花一些时间的,看个人需求.这篇仅仅是 ...

  6. javascript学习日志:前言

    javascript学习日志系列的所有博客,主要理论依据是<javascript权威指南>(犀牛书第6版)以及<javascript高级程序设计第三版>(红色书),目前js行业 ...

  7. MobileForm控件的使用方式-用.NET(C#)开发APP的学习日志

    今天继续Smobiler开发APP的学习日志,这次是做一个title.toolbar.侧边栏三种效果 样式一 一.          Toolbar 1.       目标样式 我们要实现上图中的效果 ...

  8. Sass学习第一天

    Sass学习 网站学习地址: Sass中文网:https://www.sass.hk/docs/#t7-3 Airen的博客:https://www.w3cplus.com/preprocessor/ ...

  9. 我的游戏学习日志3——三国志GBA

    我的游戏学习日志3——三国志GBA 三国志GBA由日本光荣公司1991~1995所推出<三国志>系列游戏,该作是光荣在GBA上推出的<三国志>系列作品的第一款.本游戏登场武将总 ...

随机推荐

  1. 微信token验证源码分享(c#版)

    在开发时遇到一个问题: 上线后提交申请微信提示"您的服务器没有正确响应token验证...",我查看日志发现根本就没有接收到来自微信的参数. 后来我又记录了微信请求方式和请求的字符 ...

  2. net2.0实现net3.5特性,如扩展方法,Linq等

    差不多两年没碰net了,今天想做个小工具,于是打开了久违的VS2012,由于客户终端还是winxp时代,而且是net2.0,且升级存在限制,因此必需在2.0下开发,之前的常用库是3.5写的,而且因为3 ...

  3. javascript:中文等字符转成unicode

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. 运用Edraw为WPF应用程序嵌入Office文档的方法总结

    具体描述了运用Edraw Office Viewer Component为WPF应用长须嵌入MS Word,Excel以及Power Point的方法. 打开Visual Studio,并创建一个新的 ...

  5. Selenium 2.0 以后不在必须Selenium server了

    does not require the Selenium Server to automate the browser.这个句话,解决了我很的疑惑,新版Selenium 可以直接操作浏览器了,还可以 ...

  6. supersocket 通过配置文件启动服务 总是 初始化失败的 解决办法

    <serverTypes> <add name="APPServerType" type="TMPServer.APP.APPServer, TMPSe ...

  7. (二)selenium元素定位

    selenium定位方法 Selenium提供了8种定位方式. id name class name tag name link text partial link text xpath css se ...

  8. May 27th 2017 Week 21st Saturday

    I learned the value of hard work by working hard. 只有真的努力了,才会知道努力的价值. I remember in the movie, The Da ...

  9. 20150103 海南铁汉vs哈尔滨毅腾

    本文首发于『懂球帝』 这一场球赛虽然极其普通,在各位懂球帝面前或许不值得一提,但它极具历史意义,因为这是海南第一个职业联赛队伍的首场正式比赛,同时也是海南铁汉队第一次在正式比赛中与球迷们见面. 稍做一 ...

  10. C语言 指向函数的指针

    #include <stdio.h> int sum(int a, int b) { int c = a + b; printf("%d + %d = %d\n", a ...