Sass 基本函数
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 基本函数的更多相关文章
- wepack+sass+vue 入门教程(三)
十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...
- wepack+sass+vue 入门教程(二)
六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...
- wepack+sass+vue 入门教程(一)
一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...
- 前端CSS预处理器Sass
前面的话 "CSS预处理器"(css preprocessor)的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件.SASS是一种CSS的开发工 ...
- SASS教程sass超详细教程
SASS安装及使用(sass教程.详细教程) 采用SASS开发CSS,可以提高开发效率. SASS建立在Ruby的基础之上,所以得先安装Ruby. Ruby的安装: 安装 rubyinstaller- ...
- Sass之坑Compass编译报错
前段时间在使用Compass时遇到了其为难处理的一个坑,现记录到博客希望能帮助到各位. 一.问题: 利用Koala或者是gulp编译提示如下,截图为koala编译提示错误: 二.解决办法 从问题截图上 ...
- emmet,jade,haml, slim,less,sass,coffeescript等的实战优缺点
摘要: 文章背景,来自于群内周五晚上的一次头脑风暴式的思维碰撞交流活动. 随着前端技术的蓬勃发展, 各种新技术随着生产力的需要不断的涌入我们的视野, 那今天探讨的话题是这些新时代的前端兵器谱: 一. ...
- Sass用法指南
写在前面的话:随着CSS文件越来越大,内容越来越复杂,对其进行很好的维护将变的很困难.这时CSS预处理器就能够帮上大忙了,它们往往拥有变量.嵌套.继承等许多CSS不具备的特性.有很多CSS预处理器,这 ...
- PostCSS深入学习: PostCSS和Sass、Stylus或LESS一起使用
如果你喜欢使用PostCSS,但又不想抛弃你最喜欢的预处理器.不用担心,你不需要作出二选一的选择,你可以把PostCSS和预处理器(Sass.Stylus或LESS)结合起来使用. 有几个PostCS ...
随机推荐
- 《梦断代码Dreaming In Code》阅读计划
书籍是人类宝贵的精神财富,读书是人们重要的学习方式,是人生奋斗的航灯,是文化传承的通道,是人类进步的阶梯.学生作为学习人群的主体,必须把读书作为头等大事.学校就是一个学生在教师指导下自主读书的空间,而 ...
- Java多线程同步机制之同步块(方法)——synchronized
在多线程访问的时候,同一时刻只能有一个线程能够用 synchronized 修饰的方法或者代码块,解决了资源共享.下面代码示意三个窗口购5张火车票: package com.jikexueyuan.t ...
- [STL] map,multimap,unordered_map基本用法
map的特性是,所有元素都会根据元素的键值自动被排序.map的所有元素都是pair,同时拥有键值(key)和实值(value).pair的第一元素被视为键值,第二元素被视为实值.map不允许两个元素拥 ...
- matlab exist函数
函数作用:用于确定某变量或值是否存在. 调用格式: exist主要有两种形式,一个参数和两个参数的,作用都是用于确定某值是否存在:1. b = exist( a) 若 a 存在,则 b = 1: 否则 ...
- 【bzoj4602】[Sdoi2016]齿轮 BFS
题目描述 给出一张n个点m条边的有向图,每条边 (u,v,x,y) 描述了 u 的点权乘 x 等于 v 的点权乘 y (点权可以为负).问:是否存在满足条件的图. 输入 有多组数据,第一行给定整数T, ...
- CentOS 文本搜索grep
grep 用于在文本中执行关键词搜索, 用法: grep [选项]... PATTERN [FILE]... [root@bigdata-senior01 ~]# grep "ftp&quo ...
- UOJ117:欧拉回路——题解
http://uoj.ac/problem/117 (作为一道欧拉回路的板子题,他成功的令我学会了欧拉回路) (然而我不会背……) 就两件事: 1.无向图为欧拉图,当且仅当为连通图且所有顶点的度为偶数 ...
- HDOJ(HDU).2546 饭卡(DP 01背包)
HDOJ(HDU).2546 饭卡(DP 01背包) 题意分析 首先要对钱数小于5的时候特别处理,直接输出0.若钱数大于5,所有菜按价格排序,背包容量为钱数-5,对除去价格最贵的所有菜做01背包.因为 ...
- JavaScript随机数生成方法
实现随机数是各种编程语言都很常见的一个编程任务,下面介绍一下在JavaScript如何实现随机数.第一中方法通过重写Math.random方法实现,第二种方法改自一个C实现,都可以实现编程目的. 直接 ...
- java 在centos6.5+eclipse环境下调用opencv实现sift算法
java 在centos6.5+eclipse环境下调用opencv实现sift算法,代码如下: import org.opencv.core.Core; import org.opencv.core ...