Sass 中的常用函数

一、字符串函数

  1. unquote($string): 删除字符串前后的引号,删除一对引号,如果这个字符串没有带有引号,将返回原始的字符串。

    示例:

.text1 {
content: unquote("'hello'");}

  2. quote($string): 给字符串添加引号,而且字符串中间有单引号或者空格时,需要用单引号或双引号括起,否则编译的时候将会报错(解决方案就是去掉空格,或者加上引号)。同时 quote() 碰到特殊符号,比如: !、?、> 等,除中折号 - 和 下划线_ 都需要使用双引号括起,否则编译器在进行编译的时候同样会报错.

    示例:

.text2 {
content: quote(hello-word);}

  3. 大小写转换

    to-upper-case($string);//转大写
          to-lower-case($string);//转小写

  示例:

.text3 {
text: to-upper-case(aAaA);
text: to-lower-case(aAaA);
}

二、 数字函数

    1. percentage($value):将一个不带单位的数转换成百分比值;
      2. round($value):将数值四舍五入,转换成一个最接近的整数,可以带单位;
      3. ceil($value):向上舍入为整数,可以带单位;
      4. floor($value):将一个数去除他的小数部分,可以带单位;
      5. abs($value):返回一个数的绝对值,可以带单位;
      6. min($numbers…):找出几个数值之间的最小值,可以带同类型单位;
      7. max($numbers…):找出几个数值之间的最大值,可以带同类型单位;
      8. random(): 获取随机数

  示例:

 .header {
width: percentage(.2);//20%
height: percentage(2px / 3px);//66.66667% margin: round(3.2px);//3px padding: ceil(2.1px);//3px border-width: floor(3.9px);//3px font-size: abs(-10px);//10px top: min(5px, 10px, 20px, 2px);//2px
left: max(5px, 10px, 20px, 2px);//20px border-radius: floor(random()*10px);//这个值真是不知道怎么说
}

三、 列表函数

    1. length($list):返回一个列表的长度值,函数中的列表参数之间使用空格隔开,不能使用逗号,否则函数将会出错;
      2. nth($list, $n):返回一个列表中指定的某个标签值,索引从1开始,$n必须大于0,不然报错(SyntaxError: List index 0 must be a non-zero integer for `nth')
      3. join($list1, $list2, [$separator]):将两个列给连接在一起,变成一个列表;
      4. append($list1, $val, [$separator]):将某个值放在列表的最后;
      5. zip($lists…):将几个列表结合成一个多维的列表;
      6. index($list, $value):返回一个值在列表中的位置值。

  示例:

$list:1px,2px,3px,4px,5px;
h1 {
font-size: length($list);//5
line-height: nth($list,3);
margin: index($list,5px);
}

  输出:

 h1 {
font-size:;
line-height: 3px;
margin:; }

    join() 只能将两个列表连接成一个列表,如果直接连接两个以上的列表将会报错(SyntaxError: $separator: (#ddeeee #eeffff) is not a string for `join')
    可选参数 $separator; 定义列表元素的分隔符;默认auto 自动识别;comma 使用,分割;space 使用空格分隔;

  示例:

 h2 {
content: join($list,(6px,7px,8px),space);//返回新字符串
}
h3 {
content: append($list,9px);
}
h4{
//zip()函数中每个单一列表的值对应的取其相同位置值:
content: zip((1px 2px 3px),(solid dashed dotted),(green blue red));
}

  输出:

 h2 {
content: 1px 2px 3px 4px 5px 6px 7px 8px; } h3 {
content: 1px, 2px, 3px, 4px, 5px, 9px; } h4 {
content: 1px solid green, 2px dashed blue, 3px dotted red; }

四、 Introspection函数 包含几个判断类型函数

    1. type-of($value):返回一个值的类型
           返回值:
              number 为数值型。
              string 为字符串型。
              bool 为布尔型。
              color 为颜色型。
      2. unit($number):返回一个值的单位;
      3. unitless($number):判断一个值是否带有单位,不带返回true,带单位返回false
      4. comparable($number-1, $number-2):判断两个值是否可以做加、减和合并;可以返回true,不可以反悔false

  示例:

h1{
content: type-of(true);//bool
}

五、 Miscellaneous 函数

  三元条件函数,他有两个值,当条件成立返回一种值,当条件不成立时返回另一种值:if($condition,$if-true,$if-false)

  示例:

.text4 {
padding: if(true,2px,3px);
}

  输出:

.text4 {
padding: 2px; }

六、 map 类型

  Sass中的map 常常被称为数据地图,又有人称其为数组,应为他总是以 key:value 成对出现,更像是一个JSON数据

  示例:

$color: (
default: #fff,
primary: #22ae39,
negative: #d9534f
);

 map 的函数功能。Sass中map自带七个函数
    1. map-get($map, $key): 根据key值,返回map中的相关的值
    2. map-merge($map1, $map2): 将两个 map 合并成一个新的 map
    3. map-remove($map, $key): 从map中删除一个key,返回一个新的map
    4. map-keys($map): 返回 map 中所有的key
    5. map-values($map): 返回 map 中所有的value
    6. map-has-key($map, $key): 根据给定的 key 值判断map是否有对应的value值,如果有返回true,否则返回false
    7. keywords($args): 返回一个函数的参数,这个参数可以动态的设置key和value

  map-get($map, $key) 示例:

 $social-colors: (
dribble: #ea4c89,
facebook: #3b5998,
github: #171515,
google: #db4437,
twitter: #55acee
);
.btn-dribble{
color: map-get($social-colors, facebook);
//如果 $key 不在 $map 中,不会编译出 CSS,其实 map-get 返回了一个 null 值。
background-color: map-get($social-colors, weibo);
}
/*
* map-get($map, $key) 示例
*/
.btn-dribble {
color: #3b5998; }

  map-has-key($map, $key) 示例:

 /*定义一个函数判断 $key 是否在 $map 中 否则报错*/
@function colors($color){
@if not map-has-key($social-colors, $color){
@warn "No color found for #{$color} in $social-colors map. Property omitted.";
}
@return map-get($social-colors, $color);
} .btn-dribble {
color: colors(dribble);
}
.btn-facebook {
color: colors(facebooks);
}

  输出:

.btn-dribble {
color: #ea4c89; }

Sass 基本函数的更多相关文章

  1. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  2. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  3. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

  4. 前端CSS预处理器Sass

    前面的话   "CSS预处理器"(css preprocessor)的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件.SASS是一种CSS的开发工 ...

  5. SASS教程sass超详细教程

    SASS安装及使用(sass教程.详细教程) 采用SASS开发CSS,可以提高开发效率. SASS建立在Ruby的基础之上,所以得先安装Ruby. Ruby的安装: 安装 rubyinstaller- ...

  6. Sass之坑Compass编译报错

    前段时间在使用Compass时遇到了其为难处理的一个坑,现记录到博客希望能帮助到各位. 一.问题: 利用Koala或者是gulp编译提示如下,截图为koala编译提示错误: 二.解决办法 从问题截图上 ...

  7. emmet,jade,haml, slim,less,sass,coffeescript等的实战优缺点

    摘要: 文章背景,来自于群内周五晚上的一次头脑风暴式的思维碰撞交流活动. 随着前端技术的蓬勃发展, 各种新技术随着生产力的需要不断的涌入我们的视野, 那今天探讨的话题是这些新时代的前端兵器谱: 一. ...

  8. Sass用法指南

    写在前面的话:随着CSS文件越来越大,内容越来越复杂,对其进行很好的维护将变的很困难.这时CSS预处理器就能够帮上大忙了,它们往往拥有变量.嵌套.继承等许多CSS不具备的特性.有很多CSS预处理器,这 ...

  9. PostCSS深入学习: PostCSS和Sass、Stylus或LESS一起使用

    如果你喜欢使用PostCSS,但又不想抛弃你最喜欢的预处理器.不用担心,你不需要作出二选一的选择,你可以把PostCSS和预处理器(Sass.Stylus或LESS)结合起来使用. 有几个PostCS ...

随机推荐

  1. TCP系列37—Keep Alive—1、TCP存活检测

    一.TCP存活(keepalive)检测的背景 对于TCP设计来说,如果一个客户端和服务器端建立连接后,不在进行数据传输,那么这个连接将会一直存在下去,理论上即使中间的路由器崩溃重启.或者中间的网络线 ...

  2. MySQL & export

    MySQL & export mysql export table form command line https://cn.bing.com/search?q=mysql%20export% ...

  3. Log-spectral distance

    Log-spectral distance对数频谱距离 log-spectral distance(LSD),也指 log-spectral distortion,是两个频谱之间的距离度量(用分贝表示 ...

  4. connectedSignal 简单使用

    import java.util.concurrent.CountDownLatch; public class CountDown { private static CountDownLatch c ...

  5. 【bzoj4196】[Noi2015]软件包管理器 树链剖分+线段树

    题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖(即下载安装这个 ...

  6. BZOJ4571:[SCOI2016]美味——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4571 https://www.luogu.org/problemnew/show/P3293 一家 ...

  7. LUOGU 1440

    #include<cstdio> #include<algorithm> #include<cstring> #define N 1000005 using nam ...

  8. BZOJ3172 & 洛谷3966 [Tjoi2013]单词 【fail树】

    3172: [Tjoi2013]单词 Time Limit: 10 Sec  Memory Limit: 512 MB Submit: 4293  Solved: 2083 [Submit][Stat ...

  9. 谈谈CSS中em与px的差异

    在国内网站中,包括三大门户,以及“引领”中国网站设计潮流的蓝色理想,ChinaUI等都是使用了px作为字体单位.只有百度好歹做了个可调的表率.而 在大洋彼岸,几乎所有的主流站点都使用em作为字体单位, ...

  10. foo.prototype作为新对象的原型来使用

    最近在研究js,疑惑也比较多.主要是被原型这个东西给弄迷糊了.疑惑出自于: function foo { this.name = 'foo'; } alert(foo.prototype === Fu ...