使用sass中的@mixin

为了有效的维护和开发项目,代码的重复利用就显得尤为重要。在Sass中,除了@import@extend可以使你的代码更加具有重复利用性,@mixin指令也同样能提高你代码的重复使用率并简化你的代码。

@extend指令通过继承从而简化了代码,但是它也有缺陷之处,首先是不够灵活,其次它还会将你不需要的其他地方具有相同类名的样式都继承过来。

@mixin指令是另一种简化代码的方法。Mixins可以包含任意内容且可以传递参数,因此比@extend更加灵活和强大。

定义Mixins

通过@mixin加名称的方式就可以定义一个Mixins模块,在模块内你可以添加任何你想重复使用的样式。

@mixin button-size {
    padding: 10px;
    font-size: 18px;
    border-radius: 10px
}

由于历史原因,连字符和下划线被认为是相同的,也就是说 @mixin button-large { }@mixin button_large { }是一样的。

使用@mixin指令

你可以通过@include来调用具有相同名称的mixin模块。

.button {  
    @include button-size;  
    background-color: green;  
}

在mixin模块的定义中还可以包含其他的mixin。比如:

@mixin button {  
    @include button-lg;  
    @include button-sm;  
}

所以你可以通过以包含多种简单mixin模块的方式创建较为复杂的mixin模块。

Mixins模块包含选择器和规则集,也就是mixins包含的内容本身就是有效的CSS样式时,他们就可以在其他规则集外被调用。比如本文之前创建的名为linkmixin模块:

@mixin link {  
    a {  
        color: blue;
    }
}

之后我们可以直接调用这个模块,即使不在一个选择器内。
@include link;

参数的使用

@mixin button-size($padding-x, $padding-y, $font-size, $border-radius){
    padding: $padding-y $padding-x;
    font-size: $font-size;
    border-radius: $border-radius
}

调用

// 使用$开头的都是变量,动态设置值
@include button-size($btn-padding-x, $btn-padding-y, $btn-font-size, $border-radius);

给参数设置默认值

@mixin button-style(
    $background,
    $border,
    $color,
    $hover-background: lighten($background, 7.5%), // 默认值参数
    // 比第一个参数的颜色浅上7.5%  darken($link-color, 15%) 比第一个参数的颜色深上10%
    $hover-border: lighten($border, 10%),
    $hover-color: $color
){
    color: $color;
    background: $background;
    border-color: $border;
    &:hover{
        color: $hover-color;
        background: $hover-background;
        border-color: $hover-border; 
    }
}

调用

.btn-primary {
    @include button-style($primary, $primary, $white)
}

关键字参数
为了帮助你的代码更加容易理解,你可以在传递值给mixin时将参数名称和参数值一并传递过去。

.btn-primary {
    @include button-style($background:$primary, $border: $primary, $color: $white)
}

一起传递关键字名称和值也被称为命名参数,你也可以以任意顺序传递命名参数。下面两种传递方式解析后会得到相同的结果。

.button-green {  
   @include button($background: green, $color: #fff);  
}

.button-green {  
   @include button($color: #fff, $background: green);  
}

数量可变的参数

Mixins可以接收未知数量的参数。比如你可以给同一个元素增加多种box-shadows。这里,我增加了暗灰和浅灰两种阴影。

.container {  
    box-shadow: 0px 1px 2px #333,  
                2px 3px 4px #ccc;  
}

在另一个元素上你可能只想使用一种阴影或者在其他元素上你又想使用三种或者四种阴影。这个时候你就可以创建一个接收数量可变的参数的mixin模块,并且在使用@include指令的时候决定传递参数的数量。

@mixin box-shadows($shadow...) {  
    box-shadow: $shadow;  
}

.container {  
    @include box-shadows(0px 1px 2px #333, 2px 3px 4px #ccc);  
}

通过在变量名后增加三个点(...)来使mixin模块接收数量可变的参数。需要注意的是这些是三个周期的字符,而不是单一的省略号。当你使用@include传递参数的时候,使用逗号将参数分开。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值