sass @function,@for,@mixin 的应用
项目前提:
不同的汽车显示不同的图片,一共9种汽车;每种汽车显示不同状态的图片,一共6种状态,所以一共会有54张图片
后台接口返回汽车种类分别为:1-9,汽车状态分别为:0-5
项目需求:
根据后台返回的汽车种类与状态显示不同的图片
思路:
1. 根据汽车种类和状态应用汽车样式
{[`carIcon-${car.carImg}-${car.status}-carIcon`]: true} //car对象里面存有后台返回的汽车种类carImg与状态status
2. 用@mixin定义汽车图片的基本样式
@mixin tree-icon($iconPath,$scale:1) {
background-image: url($iconPath);
width: 18px;
height: 18px;
transform: scale($scale);
background-repeat: no-repeat;
background-position: center center;
display: inline-block;
}
$iconPath表示显示的图片路径,$scale表示缩放
3. 定义函数将汽车状态码映射为图片名
@function carImgStatusName($imgStatus) {
@if $imgStatus == '0' { @return offline }
@if $imgStatus == '1' { @return online }
@if $imgStatus == '2' { @return stopaccoff}
@if $imgStatus == '3' { @return stopaccon}
@if $imgStatus == '4' { @return alarm}
@if $imgStatus == '5' { @return IOName}
@return offline
}
$imgStatus为汽车状态编码0-5,分别表示离线,在线...
因为汽车图片一般是ui给过来的,文件名开发无法确定,可能需要做映射
4. 根据汽车种类和状态定义汽车样式
//汽车种类编码1-9
@for $i from 1 through 9 {
$imgId: #{$i};
@for $j from 0 through 5 { //汽车状态编码0-5
$imgStatus: #{$j};
//将状态码映射为文件名
$name: carImgStatusName($imgStatus);
//定义样式如:.carIcon-1-0-carIcon,.carIcon-1-1-carIcon等
.carIcon-#{$imgId}-#{$imgStatus}-carIcon {
@include tree-icon('../../../../../asserts/images/icon-common-left/#{$imgId}_#{$name}.png');
}
}
}
最后编译的效果:
.carIcon-1-0-carIcon {
background-image: url();
width: 18px;
height: 18px;
transform: scale(1);
background-repeat: no-repeat;
background-position: center center;
display: inline-block; }
.carIcon-1-1-carIcon {
background-image: url();
width: 18px;
height: 18px;
transform: scale(1);
background-repeat: no-repeat;
background-position: center center;
display: inline-block; }
.carIcon-1-2-carIcon {
background-image: url();
width: 18px;
height: 18px;
transform: scale(1);
background-repeat: no-repeat;
background-position: center center;
display: inline-block; }
.carIcon-1-3-carIcon {
background-image: url();
width: 18px;
height: 18px;
transform: scale(1);
background-repeat: no-repeat;
background-position: center center;
display: inline-block; }
sass @function,@for,@mixin 的应用的更多相关文章
- sass揭秘之@mixin,%,@function
因为文章内含有很多sass代码,如需自己动手查看编译结果,推荐使用sassmeister这款在线编译工具,方便你阅读学习. 在阅读本文章之前,请先确认你已经阅读了上篇文章sass揭秘之变量,不然会给你 ...
- sass揭秘之@mixin,%,@function(转载)
因为文章内含有很多sass代码,如需自己动手查看编译结果,推荐使用sassmeister这款在线编译工具,方便你阅读学习. 在阅读本文章之前,请先确认你已经阅读了上篇文章sass揭秘之变量,不然会给你 ...
- sass揭秘之@mixin,%,@function scss基本使用及操作函数
sass揭秘之@mixin,%,@function: 地址:https://www.w3cplus.com/preprocessor/sass-mixins-function-placeholder. ...
- Sass中的mixin,function,extend
Mixins: 用于相类似的css属性将会被使用多次,每次调用时仅仅有小的参数改变: Function 用于计算得出相关值: Extend 有一批属性完全匹配时,应该使用extend
- [Sass] Level 3: Mixin -- Ex
When to use MIXIN? Better way to use MIXIN is when you deal with browser prefiex, for example: @mixi ...
- Sass的混合-@mixin,@include
1,无参数,有参数和带默认值参数的@mixin声明sass文件内容: //带参数,默认50@mixin opa($opa:50){ opacity: $opa / 100; filter:alpha( ...
- sass中常用mixin
//设置字体大小 @mixin font($s:14px,$h:1.5,$f:microsoft yahei){ font:$s/#{$h} $f; } //参数(方向,大小,颜色),默认:向下,10 ...
- sass的mixin,extend,placeholder,function
1. mixin 就是定义了一个函数,可以传参,并且设定默认值,css选择器可以通过@include来引用,mixin混入的代码,就是原样复制,不会合并,会造成冗余 例如: @mixin br6($b ...
- sass函数:@function
sass定义了很多函数可供使用,当然你也可以自己定义函数,以@fuction开始. sass的官方函数链接为:sass fuction,实际项目中我们使用最多的应该是颜色函数,而颜色函数中又以ligh ...
随机推荐
- python爬取微信信息--显示性别/地域/词云(附代码)
看到一篇有意思的博客 利用微信开放的接口itchat 可以获取登录的微信好友信息 并且利用图像工具显示分析结果 非常的有意思 记录下实现过程 并提供可执行代码 首先要 import itchat 库 ...
- 京东架构师的showtime京东个性化推荐系统实战
推荐系统核心任务是排序,从线上服务角度看,就是将数据从给定集合中数据选择出来,选出后根据一定规则策略方法进行排序. 线上服务要根据一定规则进行架构设计,架构设计是什么?每一次权衡取舍都是设计,设计需要 ...
- 配置redis
配置Redis 配置相关redis.conf bind 127.0.0.1 注释掉 否则其它远程计算机无 ...
- python常用库 - NumPy 和 sklearn入门
Numpy 和 scikit-learn 都是python常用的第三方库.numpy库可以用来存储和处理大型矩阵,并且在一定程度上弥补了python在运算效率上的不足,正是因为numpy的存在使得py ...
- 希尔排序——Shell Sort
前言: 数据序列1: 13-17-20-42-28 利用插入排序,13-17-20-28-42. Number of swap:1;数据序列2: 13-17-20-42-14 利用插入排序,13-14 ...
- 使用crypt配置Basic Auth登录认证
简介 Basic Auth用于服务端简单的登录认证,通常使用服务器Nginx.Apache本身即可完成.比如我们要限定某个域名或者页面必须输入用户名.密码才能登录,但又不想使用后端开发语言,此时Bas ...
- 带你了解CSRF和XSS(一)
浏览器的同源策略限制了一些跨域行为,但仍有些特例(img.iframe.script标签)不受跨域限制,这就给XSS攻击创造了机会(这完全不是同源策略的锅,一定是程序员的锅). 在讲下面的内容前,还是 ...
- Spring-IOC实现【01-XML配置方式】
IOC概念 IoC控制反转(IoC,Inversion of Control), 是一个概念,是一种思想.控制反转就 是对对象控制权的转移,从程序代码本身反转到了外部容器.把对象的创建.初始化. 销毁 ...
- 3DLut表实现log视频的后期调色原理
现在越来越多的视频或者图像拍摄设备支持log模式,比如大疆无人机的D-Log模式等等,log模式的起源和发展就不多做介绍,其在普通显示器上显示画面通常看起来是平坦的灰色,因此也常被称为log灰视频. ...
- .Net Core 简单定时任务框架封装
有段日子没有更新,写点东西冒个泡 .这篇文章过来讲个小东西,也是大家在日常开发中也经常需要面临的问题:后台定时任务处理.估计大家看到这句就已经联想到 QuartZ 等类似第三方类库了,不好意思,后边的 ...