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 ...
随机推荐
- Scala可变对象
Java提供JavaBean作为数据对象的封装, 而对于Scala来说也提供了同样的支持. class Apple { var weight: Float = _ var color: String ...
- UVALive - 6868 Facility Locations 想法题
题目链接: http://acm.hust.edu.cn/vjudge/problem/88634 Facility Locations Time Limit: 3000MS 题意 给你一个m*n的矩 ...
- JavaBean中DAO设计模式简介
一.信息系统的开发架构 客户层-------显示层-------业务层---------数据层---------数据库 1.客户层:客户层就是客户端,简单的来说就是浏览器. 2.显示层:JSP/Ser ...
- erlang+thrift配合开发
I think, thrift is a tcp/ip based Client-Server architecture multi-languages supported RPC framewo ...
- sql语句中的insert 和 insert into 的区别?into有什么用?
insert into tableName values(........) insert tableName (字段名1,字段名2,...)values(......)看语句结构就知道区别了 .in ...
- 几种常见web 容器比较
1:产品介绍 WebLogic是美国bea公司出品的一个application server确切的说是一个基于j2ee架构的中间件.BEA WebLogic是用于开发.集成.部署和管理大型分布式We ...
- android四大组件(一)Activity
一.创建一个新的Activity 1.android的四大组件都要在清单文件里面配置 2.如果想让你的应用有多个启动图标,你的activity需要这样配置 <intent-filter> ...
- bzoj4332[JSOI2012]分零食
一下午被这题的精度续掉了...首先可以找出一个多项式的等比数列的形式,然后类似poj的Matrix Series,不断倍增就可以了.用复数点值表示进行多次的多项式运算会刷刷地炸精度...应当用int存 ...
- 【题解】CF#983 E-NN country
首先,我们从 u -> v 有一个明显的贪心,即能向上跳的时候尽量向深度最浅的节点跳.这个我们可以用树上倍增来维护.我们可以认为 u 贪心向上跳后不超过 lca 能跳到 u' 的位置, v 跳到 ...
- [九省联考2018]IIIDX 贪心 线段树
~~~题面~~~ 题解: 一开始翻网上题解看了好久都没看懂,感觉很多人都讲得不太详细,所以导致一些细节的地方看不懂,所以这里就写详细一点吧,如果有不对的or不懂的可以发评论在下面. 首先有一个比较明显 ...