Sass 学习

一、Sass安装(windows版)

1.在 Windows 平台下安装 Ruby 需要先有 Ruby 安装包,可以到 Ruby 的官网(http://rubyinstaller.org/downloads)下载对应需要的 Ruby 版本。

在安装过程中,个人建议将其安装在 C 盘下,在安装过程中选择第二个选项(不选中,就会出现编译时找不到Ruby环境的情况)

2.安装Sass

通过命令安装  gem install sass

查看Sass版本  sass -v

更新Sass版本  gem update sass

卸载(删除)Sass  gem uninstall sass

二、Sass的语法格式及编译调试..

语法

sass 有两种, 以下都是以 scss为主 文件后辍为  *.scss  此语法格式与css语法更相似!更易学习

Sass编译

Sass 的编译有多种方法:

1、命令编译

----单文件编译:

sass <要编译的Sass文件路径>/style.scss:<要输出CSS文件路径>/style.css

------多文件编译

sass sass/:css/

上面的命令表示将项目中“sass”文件夹中所有“.scss”(“.sass”)文件编译成“.css”文件,并且将这些 CSS 文件都放在项目中“css”文件夹中。

缺点及解决方法:

在实际编译过程中,你会发现上面的命令,只能一次性编译。每次个性保存“.scss”文件之后,都得重新执行一次这样的命令。如此操作太麻烦,其实还有一种方法,就是在编译 Sass 时,开启“watch”功能,这样只要你的代码进行任保修改,都能自动监测到代码的变化,并且给你直接编译出来:

sass --watch <要编译的Sass文件路径>/style.scss:<要输出CSS文件路径>/style.css

当然,使用 sass 命令编译时,可以带很多的参数:

2、GUI工具编译

对于 GUI 界面编译工具,目前较为流行的主要有:

Koala (http://koala-app.com/)

Compass.app(http://compass.kkbox.com/)

Scout(http://mhs.github.io/scout-app/)

CodeKit(https://incident57.com/codekit/index.html)

Prepros(https://prepros.io/)

相比之下,我比较推荐使用以下两个:

Koala (http://www.w3cplus.com/preprocessor/sass-gui-tool-koala.html)

CodeKit (http://www.w3cplus.com/preprocessor/sass-gui-tool-codekit.html)

3、自动化编译

喜欢自动化研究的同学,应该都知道GruntGulp这两个东东 ,自行学习 此处就不再介绍

[Sass]常见的编译错误

在编译 Sass 代码时常常会碰到一些错误,让编译失败。这样的错误有系统造成的也有人为造成的,但大部分都是人为过失引起编译失败。

而最为常见的一个错误就是字符编译引起的。在Sass的编译的过程中,是不是支持“GBK”编码的。所以在创建 Sass 文件时,就需要将文件编码设置为“utf-8”。

另外一个错误就是路径中的中文字符引起的。建议在项目中文件命名或者文件目录命名不要使用中文字符。而至于人为失误造成的编译失败,在编译过程中都会有具体的说明,大家可以根据编译器提供的错误信息进行对应的修改。

[Sass]不同样式风格的输出方法

众所周知,每个人编写的 CSS 样式风格都不一样,有的喜欢将所有样式代码都写在同一行,而有的喜欢将样式分行书写。在 Sass 中编译出来的样式风格也可以按不同的样式风格显示。其主要包括以下几种样式风格:

嵌套输出方式 nested

在编译的时候带上参数“--style nested”:

sass --watch test.scss:test.css--style nested

展开输出方式 expanded

在编译的时候带上参数“--style expanded”:

sass --watch test.scss:test.css--style expanded

紧凑输出方式 compact

在编译的时候带上参数“--stylecompact”:

sass --watch test.scss:test.css--stylecompact

压缩输出方式 compressed

在编译的时候带上参数“--stylecompressed”:

sass --watch test.scss:test.css--stylecompressed

三 、Sass的基本特性-基础

变量: 以$ 符号开始

普通变量  $color;

默认变量  sass 的默认变量仅需要在值后面加上 !default 即可。

sass 的默认变量一般是用来设置默认值,然后根据需求来覆盖的,覆盖的方式也很简单,只需要在默认变量之前重新声明下变量即可。

$baseLineHeight: 2;

$baseLineHeight: 1.5!default;

body{   

line-height: $baseLineHeight;

}


编译后的css代码:

body{

line-height:2;

}

可以看出现在编译后的 line-height 为 2,而不是我们默认的 1.5。默认变量的价值在进行组件化开发的时候会非常有用。

理解全局变量和局部变量

http://www.sassmeister.com/ 在线学习sass的网站

嵌套 

选择器嵌套

属性嵌套

伪类嵌套

混合宏

在 Sass 中,使用“@mixin”来声明一个混合宏。

使用一个关键词“@include”来调用声明好的混合宏

注意:带参数的混合宏 如果有更多参数  可以使用“...” 来代替

[Sass]扩展/继承

通过关键词 “@extend”来继承已存在的类样式块

[Sass]占位符 %placeholder

Sass 中的占位符%placeholder 功能是一个很强大,很实用的一个功能,这也是我非常喜欢的功能。他可以取代以前 CSS 中的基类造成的代码冗余的情形。因为 %placeholder 声明的代码,如果不被 @extend 调用的话,不会产生任何代码。

[Sass]混合宏 VS 继承 VS 占位符

Sass 学习_第1张图片

[Sass]插值#{}  /*并不是很理解插件,待详细学习后更新*/


使用 CSS 预处理器语言的一个主要原因是想使用 Sass 获得一个更好的结构体系。比如说你想写更干净的、高效的和面向对象的 CSS。Sass 中的插值(Interpolation)就是重要的一部分

[Sass]注释

注释对于一名程序员来说,是极其重要,良好的注释能帮助自己或者别人阅读源码。在 Sass 中注释有两种方式,我暂且将其命名为:

1、类似 CSS 的注释方式,使用 ”/* ”开头,结属使用 ”*/ ”

2、类似 JavaScript 的注释方式,使用“//”

两者区别,前者会在编译出来的 CSS 显示,后者在编译出来的 CSS 中不会显示,

[Sass]数据类型

Sass 和 JavaScript 语言类似,也具有自己的数据类型,在 Sass 中包含以下几种数据类型:

数字: 如,1、2、13、10px;

字符串:有引号字符串或无引号字符串,如,"foo"、'bar'、baz;

颜色:如,blue、#04a3f9、rgba(255,0,0,0.5);

布尔型:如,true、false;

空值:如,null;

值列表:用空格或者逗号分开,如,1.5em 1em 0 2em、Helvetica, Arial, sans-serif。

四、Sass的基本特性-运算

你可能感兴趣的:(Sass 学习)