数据类型

在sass里有数字、字符串、列表、颜色等类型

在cmd里 输入

sass -i

就会进入到交互模式,输入的计算可以马上得到结果

type-of()可以用来得到数据类型,如:

type-of(5) -> number

注意数字类型的可以包含单位,如:

type-of(5px) -> number

字符串类型:

type-of(hello) -> string

type-of('hello') -> string

list类型:

type-of(1px solid red) -> list

type-of(5px 10px) -> list

颜色:

type-of(red)  -> color
type-of(rgb(255,0,0) -> color
type-of(#333) -> color

number 计算

2+9 -》10
2*8 -》16
(8/2) ->4 //除法要写括号

也可以包含单位

5px + 5px -> 10px
5px -2 ->3px
5px *2 ->10px 5px * 2px ->10px*px //这样就不对了哟 (10px/2px) -> 5//除法单位取消 3+2*5px->13px

好吧,都是一些小学的数学题,很简单对吧

处理数字的函数

绝对值

abs(10) -> 10;
abs(10px) -> 10px;
abs(-10px) -> 10px;

四舍五入相关

round(3.4)->3  //四舍五入
round(3.6)->4 ceil(3.2)->4 //向上取整
ceil(3.6)->4 floor(3.2)->3 //向下取整
floor(3.9)->3 percentage(600px/1000px) ->65% //百分之 min(1,2,3) -> 1 //最小值 max(2,3,4,5) -> 5 //最大值

字符串相关

//带引号和不带引号的字符串想加为带引号的字符串

"a" + b ->"ab"
a + "b" ->"ab" //字符串+数字
"ab" + 1 ->"ab1" //字符串 - 和 / 字符串
"a" - b ->"a-b"
"a" / b ->"a/b" //注意字符串不能相乘

字符串函数

大写:

$word:"hello";
to-upper-case($word) -> "HELLO"

小写:

$word:"Hello";
to-lower-case($word) -> "hello"

得到length:

$word:"Hello";
str-length($word) -> 5

得到字符串在字符串里的位置:

$word:"Hello";
str-index($word,"el") -> 2

字符串中插入字符串:

$word:"Hello";
str-insert($word,"aa",2) -> "Haaello"

颜色相关

在sass里除了关键字、十六进制、rgb和rgba之外还有一种颜色是HSL

分别表示的是 色相 0-360(deg) 饱和度 0-100% 明度 0-100%

例如:

body {
background-color:hsl(0,100%,50%);
} -》 body {
background-color: red;
}
body {
background-color:hsl(60,100%,50%);
} -》 body {
background-color: yellow;
}

也可以有透明哟

body {
background-color:hsl(60,100%,50%,0.5);
} -》 body {
background-color: rgba(255,255,0,0.5);
}

颜色函数

lighten函数和darken函数可以把颜色加深或减淡,即调整明度,第一个参数为颜色,第二个参数为百分比,例如:

$color:#ff0000;

$light-color:lighten($color,30%);

$dark-color:darken($color,30%);

.a{
color:$color;
background:$light-color;
border-color:$dark-color;
}

---》

.a {
color: #ff0000;
background: #ff9999;
border-color: #660000;
}

saturate和desaturate函数可以调整颜色的纯度

$color:hsl(0,50%,50%);

$saturate-color:saturate($color,50%);

$desaturate-color:desaturate($color,30%);

.a{
color:$color;
background:$saturate-color;
border-color:$desaturate-color;
}

--》

.a {
color: #bf4040;
background: red;
border-color: #996666;
}

用transparentize来让颜色更透明

用opatify来让颜色更不透明

$color:rgba(255,0,0,0.5);

$opacify-color:opacify($color,0.3);

$transparentize-color:transparentize($color,0.3);

.a{
color:$color;
background:$opacify-color;
border-color:$transparentize-color;
}

---》

.a {
color: rgba(255, 0, 0, 0.5);
background: rgba(255, 0, 0, 0.8);
border-color: rgba(255, 0, 0, 0.2);
}

列表类型

在sass里,用空格或者逗号隔开的值就是列表类型

如:

1px solid red

Courier,microsoft yahei

列表函数

sass里的列表类似与数组

获取列表的长度
length(5px 10x) 2 获取列表中的第几个元素
nth(5px 10px,2) 10px 获取一个元素在一个列表里的下标
index(1px solid red,solid) 2 给列表里加入新的元素
append(5px 10px,5px) 5px 10px 5px 连接两个列表
join(5px 10px,5px 0) 5px 10px 5px 0

map类型

sass里的map类型类似与js里的object

$map:(key1:value1,key2:value2,key3:value3);

map 函数

//定义一个map
$color:(light:#ffffff,dark:#000000); //获取map 的length
length($color) ->2 //得到map里key对应的值
map-get($color,dark) ->#000000 获取map里的所有键的列表
map-keys($color) ->("light","dark") //列表类型 获取map里的所有值的列表
map-values($color) -> ("#ffffff","#000000") //列表类型 判断map里是否含有这个key
map-has-key($color,light) ->true 给map里添加键值对
map-merge($color,(light-gray:#cccccc)) ->(light:#ffffff,dark:#000000,light-gray:#cccccc) 移除map里的某个键值对
map-remove($colors,light) ->(dark:#000000,light-gray:#cccccc)

boolean类型

在sass里通过> < 比较得到的值就是布尔值 true 和false

5px>3px -> true

5px<2px -> false

在sass里也可以有或 且 非

且:

(5px > 3px) and (5px < 2px) -> false
(5px > 3px) and (5px > 2px) -> true

或:

(5px > 3px) or (5px < 2px) -> true
(5px < 3px) and (5px > 2px) -> false

非:

not(5px>3px) -> false

interpolation

在sass里可以通过interpolation的方式来在变量名和属性名上拼接变量值,例如

$name:"info";
$attr:"border"; .alert-#{$name}{
#{$attr}-color:red;
}

---->

.alert-info {
border-color: red;
}

3.sass的数据类型与函数的更多相关文章

  1. SqlServer中日期和时间数据类型及函数 【转】

    来源:http://blog.csdn.net/royalwzy/article/details/6446075 日期和时间数据类型 下表列出了 Transact-SQL 的日期和时间数据类型. 数据 ...

  2. Sass中常用的函数

    字符串函数 To-upper-case() 函数将字符串小写字母转换成大写字母 To-lower-case() 函数 与 To-upper-case() 刚好相反,将字符串转换成小写字母 数字函数 S ...

  3. Oracle数据类型,函数与存储过程

    字符串类型    固定长度:char nchar    n 表示Unicode编码    可变长度: varchar2 nvarchar2 数字类型:number(P,S)P:整数位数,S小数位数   ...

  4. 小白学 Python(17):基础数据类型(函数)(下)

    人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...

  5. Lua 学习之基础篇二<Lua 数据类型以及函数库 汇总>

    引言 前面讲了运算符,这里主要对Lua的数据处理相关的数据类型和函数库进行总结归纳,后面会再接着单独分开讲解具体使用. 首先因为Lua 是动态类型语言,变量不要类型定义,只需要为变量赋值. 值可以存储 ...

  6. Sass基本数据类型和各类型的原生方法

    数据类型: 数字:1,2,3,11,10px (可以带单位) 字符串:"asd",'asd',asd (有引号和无引号都是字符串类型) 如 $name : zhang san ; ...

  7. scala基础语法(变量,数据类型,函数)

    一:常量与变量 1.常量 2.两种变量定义方式(严格与不严格) 3.Float注意点 3.注意点 变量名后加上: 类型首字母是大写 4.占位符_ 但是需要制定类型 5.scala数据类型 6.其他类型 ...

  8. 读javascript高级程序设计01-基本概念、数据类型、函数

    一. javascript构成 1.javascript实现由三部分组成: ECMAScript:核心语言功能 DOM:文档对象模型,提供访问和操作网页内容的方法和接口 BOM:浏览器对象模型,提供与 ...

  9. MySQL中关于日期、时间的数据类型和函数

    一.日期相关的数据类型 1.datetime 占用8字节,既显示了日期,又显示了时间.其表示的日期范围为“1000-01-01 00:00:00”到“9999-12-31 23:59:59” 2.da ...

随机推荐

  1. ORACLE 错误代码提示归集

    有时数据库出现问题,不是每次都有网络可查,所以把所有的ora系列的错误整理出来, 在最没有办法的时候,需要自己来解决,有了这些根据,问题会好办的.虽说对于数据库方面, DBA很强大,他们在遇到错误时, ...

  2. pku夏令营面试

    北大面试题目: 一.内存交换 内存交换(对换)的基本思想是,把处于等待状态(或在CPU调度原则下被剥夺运行权利) 的程序从内存移到辅存,把内存空间腾出来,这一过程又叫换出:把准备好竞争CPU运行的程序 ...

  3. vue.js官方文档 PDF

    链接:https://pan.baidu.com/s/1jHMBb5W 密码:gsks

  4. Python中的列表操作

    Python的列表操作可谓是功能强大且方便(相对于Java)简单.常规的操作就不说了(这不是一个入门教程),介绍几个很有特点的例子 添加 # 追加到结尾(append) li = [1, 2, 3, ...

  5. B2B电商系统开发建设的价格费用取决于哪些要素

    B2B电子商务系统平台建设开发怎么做?如何搭建一个电商系统网站平台?相信我们的企业商家在搭建电子商务系统的时候都会进行前期的系统策划,但是对于电子商务系统的构建绝大多数人都有一个误区,那就是对于电子商 ...

  6. C++反汇编第三讲,反汇编中识别虚表指针,以及指向的虚函数地址

    C++反汇编第三讲,反汇编中识别虚表指针,以及指向的虚函数地址 讲解之前,了解下什么是虚函数,什么是虚表指针,了解下语法,(也算复习了) 开发知识为了不码字了,找了一篇介绍比较好的,这里我扣过来了,当 ...

  7. angular指令监听ng-repeat渲染完成后执行自定义事件方法

    今天工作中遇到需要用到ng-repeat遍历渲染完后执行某个操作,angular本身并没有提供监听ng-repeat渲染完成的指令,所以需要自己创建自定义指令. 在ng-repeat模板实例内部会暴露 ...

  8. RabbitMQ安装步骤

    给centos安装epel yum 源 # rpm -ivh http://dl.fedoraproject.org/pub/epel/5/i386/epel-release-5-4.noarch.r ...

  9. PAT 1042. Shuffling Machine (20)

    1042. Shuffling Machine (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue Shu ...

  10. 第四届河南省ACM 序号互换 进制转换

    序号互换 时间限制: 1 Sec  内存限制: 128 MB 提交: 41  解决: 19 [提交][状态][讨论版] 题目描述 Dr.Kong设计了一个聪明的机器人卡多,卡多会对电子表格中的单元格坐 ...