超快入门sass

前言:

为了提高开发效率,前去学习sass。学完后发现非常简单,官网上前文太多,学习起来十分不效率。因此出一片这样文章,给那些想要把sass快速上手的人。

ps:阅读本文章前首先需要熟悉css          ps2:第一次写文章可能不算太好请见谅,文章末尾有介绍编译sass的编译器


变量的引入

用$符号声明变量

$color-red:red

div{color:$color-red}

编译后:

div{color:red;}

其中$color-red==$color_red

在sass中 不区分 下划线和中划线


css嵌套规则

此处借用sass官网的代码

原css代码:

#content article h1 { color: #333 }

#content article p { margin-bottom: 1.4em }

#content aside { background-color: #EEE }

利用sass嵌套可以这么写:

#content {

        article {

            h1{color:#333}

            P{margin-bottom:1.4em}

        }

    aside{background-color:#EEE}

}

应对类似:hover的伪类时,如:

#content a{color:red}

#content a:hover{color:blue}

用sass写

#content a{

        color:red;

        &:hover{color:blue}

}

如果不是很清楚结构的话,再来一个例子

sass代码:

#content{ 

     a  {   color: red;

                &:hover{color: blue}  

         }    

    &:hover{ color: #000; }

}

编译后的css:

#content a {color: red; } 

 #content a:hover { color: blue; }

#content:hover { color: #000; }


理解:&符号指向当前父级选择器,改变上文sass代码

#content{  

  a{ color: red;     

    body &:hover{color: blue} 

   } 

   body &:hover{        color: #000;    }

}

然后编译

#content a {color: red; }

 body #content a:hover { color: blue; }

body #content:hover { color: #000; }


群组选择器嵌套

sass能够减少重复的代码量,如下运用官网的例子,css:

.container h1, .container h2, .container h3 { margin-bottom: .8em }

Sass:

.container{

h1,h2,h3{margin-bottom:.8em}

}

一下子减去许多负担,有或者,sass:

nav, aside { 

   a {color: blue}  

    p {color: red;}

}

编译后的css:

nav a, aside a {  color: blue; }

nav p, aside p {  color: red; }


子组合选择器和同层组合选择器:>、+和~

此处用官网的例子:

article {

  ~ article { border-top: 1px dashed #ccc }

  > section { background: #eee }

  dl > {

    dt { color: #333 }

    dd { color: #555 }

  }

  nav + & { margin-top: 0 }

}

编译后:

article ~ article { border-top: 1px dashed #ccc }

article > footer { background: #eee }

article dl > dt { color: #333 }

article dl > dd { color: #555 }

nav + article { margin-top: 0 }

不禁让人想到了&符号

&指向父级,然而在 >+~选择器的前面加上&并不影响使用,但是面对伪类选择器&符号必须有,至于为什么,可以自己去尝试在伪类 : 符号连接的代码随便哪一边多出一个space,试试效果就明白了



嵌套属性

利用官网的例子

Sass:

nav {

  border: {

  style: solid;

  width: 1px;

  color: #ccc;

  }

}

编译后的Css:

nav {

  border-style: solid;

  border-width: 1px;

  border-color: #ccc;

}

例子二:

Sass:

nav {

      border: 1px solid #ccc {

          left: 0px;

          right: 0px;

  }

}

编译后的css:

nav {

  border: 1px solid #ccc;

  border-left: 0px;

  border-right: 0px;

}


导入sass文件

@import “sidebar”  

可以省去默认的sass和scss的文件后缀

如果要导入原生css,请将css的后缀改为scss


默认变量值

$font-size-lg:40px !default;

如果$font-size-lg变量值没有重新声明,就使用默认值40px


混合器(个人理解为可移动复制的代码块)

使用@mixin做标识,并用@include引用,官方例子如下,sass:

@mixin rounded-corners {

  -moz-border-radius: 5px;

  -webkit-border-radius: 5px;

  border-radius: 5px;

}

notice {

  background-color: green;

  border: 2px solid #00aa00;

  @include rounded-corners;

}

编译成css:

.notice {

  background-color: green;

  border: 2px solid #00aa00;

  -moz-border-radius: 5px;

  -webkit-border-radius: 5px;

  border-radius: 5px;

}

当然混合器中还能使用css,如:

@mixin no-bullets {

  list-style: none;

  li {

    list-style-image: none;

    list-style-type: none;

    margin-left: 0px;

  }

}

使用时注意父级选择器

给混合器传参


@mixin tag-color($a-color,$b-color:$a-color,$c-color:$a-color){

color:$a-color;

background-color:$b-color;

border-color:$c-color;

}

div{

@include tag-color(red);或者@include tag-color(red,blue,yellow);

}

编译后的css:

div {

color:red;

background-color:red;

border-color:red; }

选择器继承就不讲解了,不是那么容易理解的,需要的请去官网第六节查看https://www.sass.hk/guide/



最后介绍一下编辑器,在做好sass环境设置的前提下
第一种:可以使用webstorm,这里贴上如何设置的帖子
第二种:使用webpack,添加sass环境,最后打包编译(webpack很好用,但是学习起来有一定的难度这里就不做详细介绍)
第三种

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

推荐阅读更多精彩内容

  • 1、LESS的官网:http://lesscss.org 2、Sass官网地址:http://sass-lang....
    Howie223阅读 3,686评论 0 5
  • 基础 声明变量 普通变量 默认变量 变量覆盖:只需要在默认变量之前重新声明下变量即可 变量的调用 局部变量和全局变...
    Jill1231阅读 1,284评论 0 1
  • Sass入门与实战 **Sass is the most mature, stable, and powerful...
    2f3abe35f5ac阅读 714评论 0 2
  • 学习Sass(官网:Sass)之前需要了解什么是Sass,Sass全称:Syntactically Awesome...
    haoxilu阅读 500评论 0 3
  • 3篇Sci,包括一篇2区以上 考过商务英语高级 考过雅思 考过微软mos大师级 考过日语N1 练出肌肉
    yuanliang12121阅读 239评论 0 0