sass中使用 @each in 和 @for from的使用

前言

在真实项目中我们需要写很多样式的文件,需要写公用样式,就会看到很多人写的sass中的循环,刚开始也挺懵的。


一、@each in使用

$font: (
    font14:14px,
    font16:16px,
    font18:18px,
    font20:20px,
);
$backgrounds:(
    bgc14:rgb(0, 21, 255),
    bgc16:rgb(69, 170, 91),
    bgc18:rgb(255, 0, 230),
    bgc12:rgb(189, 173, 31),
);
$widthall:(
    width1:100px,
    width2:200px,
    width3:300px,
    width4:400px,
);
$variables:(
    font: $font,
    backgrounds:$backgrounds,
    widthall:$widthall,
);
@each $key,$val in $variables {
    @each $keys,$vals in $val {
        @if $key=='font'{
            .text-#{$keys} {
                font-size: $vals;
            }
        }
        @if $key=='backgrounds'{
            .text-#{$keys} {
                background: $vals;
            }
        }
        @if $key=='widthall'{
            .text-#{$keys} {
                width: $vals;
            }
        }
    }
}

编译成css后的结果:

.text-font14 {
  font-size: 14px;
}

.text-font16 {
  font-size: 16px;
}

.text-font18 {
  font-size: 18px;
}

.text-font20 {
  font-size: 20px;
}

.text-bgc14 {
  background: #0015ff;
}

.text-bgc16 {
  background: #45aa5b;
}

.text-bgc18 {
  background: #ff00e6;
}

.text-bgc12 {
  background: #bdad1f;
}

.text-width1 {
  width: 100px;
}

.text-width2 {
  width: 200px;
}

.text-width3 {
  width: 300px;
}

.text-width4 {
  width: 400px;
}

二、@for from使用


$colors:red rgb(255, 0, 115) rgb(0, 85, 255) rgb(72, 255, 0) ;
@for $var from 1 through length($colors) {
    .tex-#{$var} {
        font-size:nth($colors,$var)
    }
}


编译css后的结果:

.tex-1 {
  font-size: red;
}

.tex-2 {
  font-size: #ff0073;
}

.tex-3 {
  font-size: #0055ff;
}

.tex-4 {
  font-size: #48ff00;
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值