1.1下载地址:

  http://rubyinstaller.org/downloads

2.1 安装

SASS是Ruby语言写的,但是两者的语法没有关系。不懂Ruby,照样使用。只是必须先安装Ruby,然后再安装SASS。

假定你已经安装好了Ruby,接着在命令行输入下面的命令:

  gem install 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 compressed test.sass test.css

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

  // watch a file

  sass --watch input.scss:output.css

  // watch a directory

  sass --watch app/sass:public/stylesheets

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

三、基本用法

 变量

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

Sass源代码:

$blue:#1875e7;
div{
color:$blue;
} $side:left;
/*asassdf*/
.rounded{
.round{
border-#{$side}-radius:5px;
} } /*计算能力*/
$var:2;
body{
margin: (14px/2);
top:50px + 100px;
right:$var * 20%;
} /*嵌套*/
div h1{
color:red;
} /*也可以写成这样*/
/*属性的嵌套必须要在属性后成加上冒号*/
p{
border:{
color:red; }
}
/*关于注释:
又斜杠是在css文件中是不显示的;
C++方式注释的方法会留在CSS文件中;
*/ /*继承*/
.class1{
margin:0 auto;
border:1px solid #000;
}
.class2{
@extend .class1;
font-size:120%;
} /*Mixin 宏的使用*/
@mixin left{ //定义mixin宏
float:left;
margin-left:10px;
} div{
@include left; //@include 用于引用minxin宏; } /*带参数的minxin宏*/
@mixin left($value:20px){
float:left;
margin-right:$value;
} //使用带参数的mixin宏;
div{
@include left(40px); } /*Sass高级语法*/
//@if 语句的使用;
p{
@if 1 + 1 == 2{
border:1px solid #000;
} @if 3 < 2{
border:2px solid #fff; }
}
//@else 语句的使用;
/*
@function linghtness($value){
@return $value;
}
$color:20%;
@if linghtness($color) > 30%{
background-color:#000;
}@else{
background-color:#fff;
}*/ //for 语句的使用;
@for $i from 1 to 5 {
.itme-#{$i} {width:100px; height:100px; }
} //while语句 $i:6; @while $i > 0 {
.itme-#{$i} {width: 2em * $i;}
$i:$i - 2; } //each命令
@each $member in a, b, c, d, f{ .#{$member}{
background-image:url("../images/#{$member}.jpg");
}
}

对应生成的CSS文件:

@charset "UTF-8";
div {
color: #1875e7;
} /*asassdf*/
.rounded .round {
border-left-radius: 5px;
} /*计算能力*/
body {
margin: 7px;
top: 150px;
right: 40%;
} /*嵌套*/
div h1 {
color: red;
} /*也可以写成这样*/
/*属性的嵌套必须要在属性后成加上冒号*/
p {
border-color: red;
} /*关于注释:
又斜杠是在css文件中是不显示的;
C++方式注释的方法会留在CSS文件中;
*/
/*继承*/
.class1, .class2 {
margin: 0 auto;
border: 1px solid #000;
} .class2 {
font-size: 120%;
} /*Mixin 宏的使用*/
div {
float: left;
margin-left: 10px;
} /*带参数的minxin宏*/
div {
float: left;
margin-right: 40px;
} /*Sass高级语法*/
p {
border: 1px solid #000;
} /*
@function linghtness($value){
@return $value;
}
$color:20%;
@if linghtness($color) > 30%{
background-color:#000;
}@else{
background-color:#fff;
}*/
.itme-1 {
width: 100px;
height: 100px;
} .itme-2 {
width: 100px;
height: 100px;
} .itme-3 {
width: 100px;
height: 100px;
} .itme-4 {
width: 100px;
height: 100px;
} .itme-6 {
width: 12em;
} .itme-4 {
width: 8em;
} .itme-2 {
width: 4em;
} .a {
background-image: url("../images/a.jpg");
} .b {
background-image: url("../images/b.jpg");
} .c {
background-image: url("../images/c.jpg");
} .d {
background-image: url("../images/d.jpg");
} .f {
background-image: url("../images/f.jpg");
}

Sass学习的更多相关文章

  1. Sass学习笔记(补充)

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

  2. Sass学习第一天

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

  3. Sass学习笔记之入门篇

    Sass又名SCSS,是CSS预处理器之一,,它能用来清晰地.结构化地描述文件样式,有着比普通 CSS 更加强大的功能. Sass 能够提供更简洁.更优雅的语法,同时提供多种功能来创建可维护和管理的样 ...

  4. gulp + webpack + sass 学习

    笔记: new webpack.optimize.CommonsChunkPlugin 核心作用是抽离公共代码,chunks:['index.js','main.js'] 另一个作用就是单独生成一个j ...

  5. sass学习笔记1

    less在处理CSS动画时,非常恶心,决定转向sass了.sass诞生得比less早,只是因为它是ruby写的,因此受众面够少.但我们不需要自己下编译器或使用命令行,我们可以koala这神器 首先几个 ...

  6. sass学习(2)——关于变量

    定义一个sass变量 可以说,变量是一个编程语言的基础.所以对于sass来说,变量肯定是浓墨重彩的其中一笔,当然函数也是.那我们如何声明定义一个sass的变量呢? 变量的符号$ 变量名称 变量的值 那 ...

  7. sass学习(1)——了解sass

    为什么要选择sass 我们在手写css中,会遇到很多很麻烦的问题.倒不是一些技术的问题,而是工程量的问题.例如,如何可以代替难记的16进制颜色,如何可以让层次更清晰,还有重复的代码该如何偷懒.其实这一 ...

  8. sass 学习

    本来看了阮一峰和于江水两位老师的博客,有看了ionic自带的sass文件,原以为自己已经是很熟悉,精通了.可是我居然连ruby都不知道真实惭愧啊,辛亏看了www.sass.hk  我想这篇官方文档肯定 ...

  9. 菜鸟的 Sass 学习笔记

    介绍 sass 是什么?? 在sass的官网,它是这么形容给自己的 Sass is the most mature, stable, and powerful professional grade C ...

  10. SASS学习笔记!(持续学习中..)

    工具  : koala 学习网址 : http://www.w3cplus.com/sassguide/syntax.html  http://sass-lang.com/documentation/ ...

随机推荐

  1. 细谈Java

    重载:相同函数名,不同参数. 重写(覆写):父类和子类之间的,子类重写了父类的方法. java的多态:重载+覆写 1.      Main方法: 是public的,也是static,也是void的,参 ...

  2. WCF服务部署到IIS上,然后通过web服务引用方式出现错误的解决办法

    本文转载:http://www.cnblogs.com/shenba/archive/2012/01/06/2313932.html 昨天在用IIS部署一个WCF服务时,碰到了如下错误: 理解了文档内 ...

  3. linux下使用fscanf实现scanf

    首先,我们知道,linux下的scanf标准库函数是一个可变参的函数,那么,我们自己要实现一个scanf也必须是一个可变参的. 其实,在liunx的库中就提供了这样的的宏,来方便我们自己来实现变参函数 ...

  4. 数学之路-分布式计算-disco(4)

    第一个參数iter是一个迭代器,涉及被map函数产生的键和值.它们是reduce实例. 在本例中.单词随机被托付给不同的reduce实例.然后,要单词同样,处理它的reduce也同样.可确保终于合计是 ...

  5. 淘宝分布式数据层:TDDL[转]

    淘宝根据自己的业务特点开发了TDDL(Taobao Distributed Data Layer 外号:头都大了 ©_Ob)框架,主要解决了分库分表对应用的透明化以及异构数据库之间的数据复制,它是一个 ...

  6. ※C++随笔※=>☆C++基础☆=>※№→C++中 #include<>与#include""

    #include<> 使用尖括号表示在包含文件目录中去查找(包含目录是由用户在设置环境时设置的),而不在源文件目录去查找: #include"" 使用双引号则表示首先在 ...

  7. MySQL 错误日志(Error Log)

    同大多数关系型数据库一样,日志文件是MySQL数据库的重要组成部分.MySQL有几种不同的日志文件.通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等. 这些日志能够帮助我们定位mysqld ...

  8. Qt 学习之路 :Repeater

    前面的章节我们介绍过模型视图.这是一种数据和显示相分离的技术,在 Qt 中有着非常重要的地位.在 QtQuick 中,数据和显示的分离同样也是利用这种“模型-视图”技术实现的.对于每一个视图,数据元素 ...

  9. Python之路【第十七篇】:Django之【进阶篇】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

  10. mysql修改root密码的方法

    方法1: 用SET PASSWORD命令 首先登录MySQL. 格式:mysql> set password for 用户名@localhost = password('新密码'); 例子:my ...