搜索
Sass学习Nov 23, 2016 pm 03:19 PM
sass

一、什么是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);

}

 


声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
揭开屏幕读取器的神秘面纱:可访问的表格和最佳实践揭开屏幕读取器的神秘面纱:可访问的表格和最佳实践Mar 08, 2025 am 09:45 AM

这是我们在形式可访问性上进行的小型系列中的第三篇文章。如果您错过了第二篇文章,请查看“以:focus-visible的管理用户焦点”。在

将框阴影添加到WordPress块和元素将框阴影添加到WordPress块和元素Mar 09, 2025 pm 12:53 PM

CSS盒子阴影和轮廓属性获得了主题。让我们查看一些在真实主题中起作用的示例,以及我们必须将这些样式应用于WordPress块和元素的选项。

使用GraphQL缓存使用GraphQL缓存Mar 19, 2025 am 09:36 AM

如果您最近开始使用GraphQL或审查了其优点和缺点,那么您毫无疑问听到了诸如“ GraphQl不支持缓存”或

使您的第一个自定义苗条过渡使您的第一个自定义苗条过渡Mar 15, 2025 am 11:08 AM

Svelte Transition API提供了一种使组件输入或离开文档(包括自定义Svelte Transitions)时动画组件的方法。

优雅且酷的自定义CSS卷轴:展示柜优雅且酷的自定义CSS卷轴:展示柜Mar 10, 2025 am 11:37 AM

在本文中,我们将深入研究滚动条。我知道,这听起来并不魅力,但请相信我,一个精心设计的页面是齐头并进的

展示,不要说展示,不要说Mar 16, 2025 am 11:49 AM

您花多少时间为网站设计内容演示文稿?当您撰写新的博客文章或创建新页面时,您是在考虑

使用Redwood.js和Fauna构建以太坊应用使用Redwood.js和Fauna构建以太坊应用Mar 28, 2025 am 09:18 AM

随着最近比特币价格超过20k美元的攀升,最近打破了3万美元,我认为值得深入研究创建以太坊

NPM命令是什么?NPM命令是什么?Mar 15, 2025 am 11:36 AM

NPM命令为您运行各种任务,无论是一次性或连续运行的过程,例如启动服务器或编译代码。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境