sass的一些小点点

1、什么是sass?

SASS是一种CSS的开发工具,是一种优秀的前端样式预处理器。
提供了许多便利的写法,大大节省了设计者的时间,使得CSS的开发,变得简单和可维护。

2、安装和使用

因为sass是基于ruby的,所以我们首先要对ruby进行安装:

ruby安装配置

下载Ruby(emmm最好不要下载最新版本,不稳定?)

Window 系统下,我们可以使用 RubyInstaller 来安装 Ruby 环境;
首先,我们进入ruby官网进行对应版本的下载并进行安装:


双击 rubyinstaller-2.5.0.exe 文件,启动 Ruby 安装向导。
点击 Next,继续向导,记得勾选 Add Ruby executables to your PATH,直到 Ruby 安装程序完成 Ruby 安装为止。

检测Ruby安装是否成功

安装完成后 在命令行进行检测看是否安装成功
输入ruby -v,显示版本则表示安装成功

ruby安装成功后,我们就可以进行sass的安装了

sass安装

在开始菜单中,找到刚才我们安装的ruby,打开Start Command Prompt with Ruby
输入gem install sass 显示如下就说明安装成功了

image.png

下面我们来看一下sass的版本
输入sass -v ,显示如下,可见sass已成功安装

3、简单压缩一个css文件

SASS文件就是普通的文本文件,里面可以直接使用CSS语法。文件后缀名是.scss,意思为Sassy CSS。

首先打开hbuilder创建一个名为sass的项目,在此项目下创建mysass.scss文件,在这个文件里随便写些样式,例如:

body{
    margin:0;
    padding:0;
}
ul{
    margin:0;
    padding:0; 
}
li{
    list-style:none;
}

接下来我们开始压缩它:
打开当前目录的命令行,输入sass -style compressed mysass.scss mysass.css,如图所示:


我们继续返回hbuilder会发现已经压缩成功了:出现了mysass.css文件和mysass.css.map文件

打开mysass.css文件 我们会看到压缩过的代码:

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

 // watch a file
  sass --watch input.scss:output.css
// watch a directory
  sass --watch app/sass:public/stylesheets

(这里的input和output均为你自己命名的输入输出文件名,)

4、sass的基本用法

(1) 变量

sass允许使用变量,所有变量以$开头。
定义一个名为“timi”的变量,让它的值为灰色:

/*jianting.scss*/
$timi:#eeeeee;
div{
    color:$timi;
}

保存后,我们可以启动sass的监听,在文件目录下打开命令行,输入sass --watch jianting.scss:jianting.css实时监听(改变scss文件代码并保存后,css文件同步更新)


如果变量需要镶嵌在字符串之中,就必须需要写在#{}之中。
定义左边圆角为5px:

$side : left;
  div {
    border-#{$side}-radius: 5px;
  }
scss文件

css文件

(2)计算功能

sass允许在代码中使用算式:

       $var:40;
  body {
    margin: (14px/2);
    top: 50px + 100px;
    right: $var * 10%;
  }
scss

css

(3) 嵌套

sass允许选择器嵌套。比如,下面的css代码:

div h1 {
    color : red;
  }

可以写成:

  div {
    h1{
      color:red;
    }
  }

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

  p {
    border: {
      color: red;
    }
  }

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

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

  a {
    &:hover { color: #ffb3ff; }
  }

(4)注释

sass共有两种注释风格。
标准的CSS注释 /* comment */ ,会保留到编译后的文件。
单行注释 // comment,只保留在SASS源文件中,编译后被省略。


scss
css

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

  /*! 
    重要注释!
  */

5、代码的重用

(1)继承(用@extend)

sass允许一个选择器,继承另一个选择器。比如,现有class1:

  .class1 {
    border: 1px solid #eee;
  }

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

  .class2 {
    @extend .class1;
    font-size:120%;
  }

(2) Mixin

Mixin有点像C语言的宏(macro),是可以重用的代码块。
使用@mixin命令,定义一个代码块。

  @mixin left {
    float: left;
    margin-left: 10px;
  }

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

  div {
    @include left;
  }

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

  @mixin left($value: 10px) {
    float: left;
    margin-right: $value;
  }

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

  div {
    @include left(20px);
  }

下面是一个mixin的实例,我们需要body的宽高都重用变量MyWidth和MyHeight的:

$MyWidth:100px;
$MyHeight:100px;
@mixin timi($w,$h){
   width:$w;
   height:$h;
}
body{
@include timi($MyWitdh,$MyHeight);

sass文件:


(3) 插入文件

@import命令,用来插入外部文件。
@import "path/filename.scss";
如果插入的是.css文件,则等同于css的import命令。
@import "bianliang.css";

6、高级用法

(1)条件语句

@if可以用来判断:

  p {
    @if 1 + 1 == 2 { border: 1px solid; }
    @if 5 < 3 { border: 2px dotted; }
  }

配套的还有@else命令:

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

(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");
    }
  }

(3)自定义函数

sass允许用户编写自己的函数:

$ttt : 5;
   @function Timi($t){
       @return $t + 2;
   }
   body{
       margin: Timi($ttt)px;
   }

emmm,基本上sass的一些小点点差不多练习到了,基本的使用可能也许maybe差不多。。。emmmm下来还是多练习吧~over

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351