// 多值变量代表的是多维数据的存储方式,换句话说,list相当于js中的数组map相当于js中的对象。
// list数据一般用空格分割, 但是也可以用 逗号 或者小括号分割多个值。
list:
$list:(20px 40px)(30px 20px)(40px 30px);//相当于多维数组,其他格式同理;
$list:20px 30px 40px 50px 60px;
$list:20px,30px,40px,50px,60px;
// 使用:对于list的使用,可以使用 nth($list,num)去调用;
// 当然我们还可以去使用其他方式;
length($list) //返回list的长度
nth($list, $n) //返回索引的项目
set-nth($list, $n, $value) //设置list中第n个的值
join($list1, $list2, [$separator]) //将两个列表链接在一起
append($list1, $val, [$separator]) //追加一个值到列表最后
zip($lists…) //将几个列表组合成多维列表
index($list, $value) //返回一个列表中值的位置
$list:(top 20px 30px) (left 40px 50px) (right 60px 70px);
@each $name,$width,$height in $list{
.box-#{$name}{
width:$width;
height:$height;
}
}
map:
// map的数据是以键值对形式出现的,期中value可以是list。格式为
$map:(key1:value1, key2:value2, key3:value3)。
// 最常用的取值方法就是用map-get($map,$key) 进行取值
// 关于map还有很多函数:
map-get($map, $key) //返回key值;
map-merge($map1, $map2) //合并两个$map;
map-remove($map, $keys…) //删除某个value并返回value值;
map-keys($map) //以list形式返回所有$map 的key;
map-values($map) //以list形式返回所有$map中的value;
map-has-key($map, $key) //查看当前的$map是否有这个key
keywords($args) //返回一个关键字
$headers:(h1:20px,h2:30px,h3:40px);
@each $key, $value in $headers{
#{$key}{
font-size: $value;
}
}
// 这里的each用法那和我们js中的for-in用法基本一致,只不过写法不同。
// $key 相当于for-in中的变量,$value 相当于for-in中的obj[i];