入门Sass——文档笔记

  • 将局部变量转换为全局变量可以添加!global声明
  • SassScript支持CSS的两种字符串类型:有引号字符串和无引号字符串,只有一种情况例外,使用#{}时,有引号字符串会被便宜为无引号字符串,便于再mixin中引用选择器名:
    @mixin firefox-message($selector) {
    body.firefox #{$selector}:before {
    content: "Hi, Firefox users!";
    }
    }
    @include firefox-message(".header");
    编译为
    body.firefox .header:before {
    content: "Hi, Firefox users!"; }
  • 用 () 表示不包含任何值的空数组(在 Sass 3.3 版之后也视为空的 map)。空数组不可以直接编译成 CSS
  • 如果需要使用变量,同时又要确保 / 不做除法运算而是完整地编译到 CSS 文件中,只需要用 #{} 插值语句将变量包裹。
    p {
    $font-size: 12px;
    $line-height: 30px;
    font: #{$font-size}/#{$line-height};
    }
    编译为
    p {
    font: 12px/30px; }
  • 颜色值的运算是分段计算进行的,也就是分别计算红色,绿色,以及蓝色的值:
    p {
    color: #010203 + #040506;
    }
    计算 01 + 04 = 05 02 + 05 = 07 03 + 06 = 09,然后编译为
    p {
    color: #050709; }
  • 需要注意的是,如果颜色值包含 alpha channel(rgba 或 hsla 两种颜色值),必须拥有相等的 alpha 值才能进行运算,因为算术运算不会作用于 alpha 值。
  • 颜色值的 alpha channel 可以通过 opacify 或 transparentize 两个函数进行调整。
    $translucent-red: rgba(255, 0, 0, 0.5);
    p {
    color: opacify($translucent-red, 0.3);
    background-color: transparentize($translucent-red, 0.25);
    }
    编译为
    p {
    color: rgba(255, 0, 0, 0.8);
    background-color: rgba(255, 0, 0, 0.25); }
  • 注意,如果有引号字符串(位于 + 左侧)连接无引号字符串,运算结果是有引号的,相反,无引号字符串(位于 + 左侧)连接有引号字符串,运算结果则没有引号。
    p:before {
    content: "Foo " + Bar;
    font-family: sans- + "serif";
    }
    编译为
    p:before {
    content: "Foo Bar";
    font-family: sans-serif; }
  • 在有引号的文本字符串中使用 #{} 插值语句可以添加动态的值:
    p:before {
    content: "I ate #{5 + 10} pies!";
    }
    编译为
    p:before {
    content: "I ate 15 pies!"; }
  • 通过 #{} 插值语句可以在选择器或属性名中使用变量:
    $name: foo;
    $attr: border;
    p.#{$name} {
    #{$attr}-color: blue;
    }
  • 可以在变量的结尾添加 !default 给一个未通过 !default 声明赋值的变量赋值,此时,如果变量已经被赋值,不会再被重新赋值,但是如果变量还没有被赋值,则会被赋予新的值。
    $content: "First content";
    $content: "Second content?" !default;
    $new_content: "First time reference" !default;
    #main {
    content: $content;
    new-content: $new_content;
    }
    编译为
    #main {
    content: "First content";
    new-content: "First time reference"; }
  • 导入文件也可以使用 #{ } 插值语句,但不是通过变量动态导入 Sass 文件,只能作用于 CSS 的 url() 导入方式:
    $family: unquote("Droid+Sans");
    @import url("http://fonts.googleapis.com/css?family=#{$family}");
    编译为
    @import url("http://fonts.googleapis.com/css?family=Droid+Sans");
  • Sass 中 @media 指令与 CSS 中用法一样,只是增加了一点额外的功能:允许其在 CSS 规则中嵌套。如果 @media 嵌套在 CSS 规则内,编译时,@media 将被编译到文件的最外层,包含嵌套的父选择器。这个功能让 @media 用起来更方便,不需要重复使用选择器,也不会打乱 CSS 的书写流程。
    .sidebar {
    width: 300px;
    @media screen and (orientation: landscape) {
    width: 500px;
    }
    }
    编译为
    .sidebar {
    width: 300px; }
    @media screen and (orientation: landscape) {
    .sidebar {
    width: 500px; } }
  • @media 甚至可以使用 SassScript(比如变量,函数,以及运算符)代替条件的名称或者值:
    $media: screen;
    $feature: -webkit-min-device-pixel-ratio;
    $value: 1.5;
    @media #{$media} and ($feature: $value) {
    .sidebar {
    width: 500px;
    }
    }
    编译为
    @media screen and (-webkit-min-device-pixel-ratio: 1.5) {
    .sidebar {
    width: 500px; } }
  • @extend 的作用是将重复使用的样式 (.error) 延伸 (extend) 给需要包含这个样式的特殊样式(.seriousError),刚刚的例子:
    .error {
    border: 1px #f00;
    background-color: #fdd;
    }
    .error.intrusion {
    background-image: url("/image/hacked.png");
    }
    .seriousError {
    @extend .error;
    border-width: 3px;
    }
    编译为
    .error, .seriousError {
    border: 1px #f00;
    background-color: #fdd; }
    .error.intrusion, .seriousError.intrusion {
    background-image: url("/image/hacked.png"); }
    .seriousError {
    border-width: 3px; }
  • 暂时不可以将选择器列 (Selector Sequences),比如 .foo .bar 或 .foo + .bar,延伸给其他元素,但是,却可以将其他元素延伸给选择器列:
    #fake-links .link {
    @extend a;
    }
    a {
    color: blue;
    &:hover {
    text-decoration: underline;
    }
    }
    编译为
    a, #fake-links .link {
    color: blue; }
    a:hover, #fake-links .link:hover {
    text-decoration: underline; }
  • 在指令中使用 @extend 时(比如在 @media 中)有一些限制:Sass 不可以将 @media 层外的 CSS 规则延伸给指令层内的 CSS,这样会生成大量的无用代码。也就是说,如果在 @media (或者其他 CSS 指令)中使用 @extend,必须延伸给相同指令层中的选择器。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,711评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,932评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,770评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,799评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,697评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,069评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,535评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,200评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,353评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,290评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,331评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,020评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,610评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,694评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,927评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,330评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,904评论 2 341

推荐阅读更多精彩内容

  • 基础 声明变量 普通变量 默认变量 变量覆盖:只需要在默认变量之前重新声明下变量即可 变量的调用 局部变量和全局变...
    Jill1231阅读 1,267评论 0 1
  • 本文简单的介绍SASS预处理语言,更多的应用请参考官方文档 一、什么是SASS 二、为什么使用SASS 三、安装S...
    CharlesDarwin阅读 416评论 0 0
  • CSS 预处理器技术已经非常的成熟,而且也涌现出了越来越多的 CSS 的预处理器框架。本文向你介绍使用最为普遍的三...
    Mx勇阅读 1,290评论 0 7
  • 再谈CSS 预处理器2016-09-09 Justineo JavaScript转自:http://efe.bai...
    抓住时间的尾巴吧阅读 1,537评论 0 2
  • 使人有面前之誉,不若使人无背后之毁 使人有乍交之欢,不若使人无久处之厌
    性本善良阅读 219评论 0 0