When to use MIXIN?

Better way to use MIXIN is when you deal with browser prefiex, for example:

@mixin transition($val...){
-webkit-transition: $val;
-moz-transition: $val;
transition: $val;
}

Because when you use mixin, actually you just copy the mixin to the another css class, it is not efficent way to wirte css.

But if use it with browser prefix, it can save your typing and you can pass in variable, make it more dynamic.

Notice: $val..., the reason to use ... is because somtime you will passin the value like:

color 0.3s ease-in, background-color 0.5s ease-out

You have , inside, it will casuse problem if you don't give ... after $val.

There is another way to use ...

@mixin button($radius, $color){
border-radius: $radius;
color: $color;
} $props = "4px, #ccc"; .btn-a {
@include button($props...)
}

Sass is smart enought to set $radius to 4px and color to #ccc. But you need to make sure the order is correct.

Default value:

.mtn-select{
@include field-border($top: 'top', $right: 'right', $bottom: '', $left:'left');
@include filed-validation;
@include filed-common;
margin-top: 0px;
& .md-select-icon{
margin-right: 18px;
} }
@mixin field-border($top:top, $right:right, $bottom:bottom, $left:left){
border-#{$top}: 1px solid rgba(0,0,0,0.12) !important;
border-#{$left}: 1px solid rgba(0,0,0,0.12) !important;
border-#{$right}: 1px solid rgba(0,0,0,0.12) !important;
border-#{$bottom}: 1px solid rgba(0,0,0,0.12) !important;
}

INCLUDE

We've identified a set of properties that commonly appear in our stylesheet (sometimes with minor tweaks). Let's streamline the process of using these values by adding the commented lines to a mixin called assemble, then calling that mixin in .factory and.highrise.

// background: #fff;
// border: 1px solid #ccc;
// padding: 10px; @mixin assemble{
background: #fff;
border: 1px solid #ccc;
padding: 10px;
} .factory {
@include assemble
}
.highrise {
@include assemble
}

ARGUMENT

That's a good start, but we need the ability to change the background color. Alter the mixin to take an argument called $bg, which should then be set as the value of the background property. Pass#fff in for .factory and #797979 in for .highrise.

@mixin assemble {
background: #fff;
border: 1px solid #ccc;
padding: 10px;
} .factory {
@include assemble;
}
.highrise {
@include assemble;
}

Answer:

@mixin assemble($bg) {
background: $bg;
border: 1px solid #ccc;
padding: 10px;
} .factory {
@include assemble(#fff);
}
.highrise {
@include assemble(#797979);
}

DEFAULT ARGUMENT

The background color for declarations using assemble will most often be #fff. Add a default value to the $bg argument to reflect this discovery. Note: once the default value is set, remember to update your .factory @include.

@mixin assemble($bg) {
background: $bg;
border: 1px solid #ccc;
padding: 10px;
} .factory {
@include assemble(#fff);
}
.highrise {
@include assemble(#797979);
}

Answer:

@mixin assemble($bg:#fff) {
background: $bg;
border: 1px solid #ccc;
padding: 10px;
} .factory {
@include assemble;
}
.highrise {
@include assemble(#797979);
}

MULTIPLE ARGUMENTS

Some elements also need a nonstandard amount of padding. Create a second argument, $pad, with a default value of 10px.factory uses the default value, but .highrise should have 20pxof padding on all sides.

@mixin assemble($bg: #fff) {
background: $bg;
border: 1px solid #ccc;
padding: 10px;
} .factory {
@include assemble;
}
.highrise {
@include assemble(#797979);
}

Answer:

@mixin assemble($bg: #fff , $pad:10px) {
background: $bg;
border: 1px solid #ccc;
padding: $pad;
} .factory {
@include assemble;
}
.highrise {
@include assemble(#797979, 20px);
}

KEYWORD ARGUMENTS

Given the number of people collaborating on this stylesheet, we should make the mixin call as clear as possible. Add $bg: and $pad: to the .highrise @include arguments, creating keyword arguments.

@mixin assemble($bg: #fff, $pad: 10px) {
background: $bg;
border: 1px solid #ccc;
padding: $pad;
} .factory {
@include assemble;
}
.highrise {
@include assemble(#797979, 20px);
}

Answer:

@mixin assemble($bg: #fff, $pad: 10px) {
background: $bg;
border: 1px solid #ccc;
padding: $pad;
} .factory {
@include assemble;
}
.highrise {
@include assemble($bg: #797979, $pad: 20px);
}

INTERPOLATING ARGUMENTS

A change request just came in: the border should only apply to one side of these elements. Add a required argument $side to the mixin and interpolate that value to the border property (passingleft as $side should create border-left: 1px solid #ccc, for instance). .factory borders should be on the left side, .highrise borders on the right. As a reminder, arguments without default values need to come before arguments with default values.

@mixin assemble($bg: #fff, $pad: 10px) {
background: $bg;
border: 1px solid #ccc;
padding: $pad;
} .factory {
@include assemble;
}
.highrise {
@include assemble($bg: #797979, $pad: 20px);
}

Answer:

@mixin assemble($side, $bg: #fff, $pad: 10px) {
background: $bg;
border-#{$side}: 1px solid #ccc;
padding: $pad;
} .factory {
@include assemble(left);
}
.highrise {
@include assemble(right, $bg: #797979, $pad: 20px);
}

VARIABLE ARGUMENTS

We're attempting to pass a comma-separated box-shadow value into our mixin as an argument, but we keep getting an error about the number of arguments. Alter $shadow to be a variable argument and accept the value below.

@mixin modal($shadow) {
box-shadow: $shadow;
border: 1px solid #ccc;
} .modal {
@include modal(inset 0 0 5px #000, 0 2px 5px #000);
}

Answer:

@mixin modal($shadow...) {
box-shadow: $shadow;
border: 1px solid #ccc;
} .modal {
@include modal(inset 0 0 5px #000, 0 2px 5px #000);
}

[Sass] Level 3: Mixin -- Ex的更多相关文章

  1. sass揭秘之@mixin,%,@function scss基本使用及操作函数

    sass揭秘之@mixin,%,@function: 地址:https://www.w3cplus.com/preprocessor/sass-mixins-function-placeholder. ...

  2. sass揭秘之@mixin,%,@function

    因为文章内含有很多sass代码,如需自己动手查看编译结果,推荐使用sassmeister这款在线编译工具,方便你阅读学习. 在阅读本文章之前,请先确认你已经阅读了上篇文章sass揭秘之变量,不然会给你 ...

  3. sass揭秘之@mixin,%,@function(转载)

    因为文章内含有很多sass代码,如需自己动手查看编译结果,推荐使用sassmeister这款在线编译工具,方便你阅读学习. 在阅读本文章之前,请先确认你已经阅读了上篇文章sass揭秘之变量,不然会给你 ...

  4. Sass的混合-@mixin,@include

    1,无参数,有参数和带默认值参数的@mixin声明sass文件内容: //带参数,默认50@mixin opa($opa:50){ opacity: $opa / 100; filter:alpha( ...

  5. sass中常用mixin

    //设置字体大小 @mixin font($s:14px,$h:1.5,$f:microsoft yahei){ font:$s/#{$h} $f; } //参数(方向,大小,颜色),默认:向下,10 ...

  6. Sass中的mixin,function,extend

    Mixins: 用于相类似的css属性将会被使用多次,每次调用时仅仅有小的参数改变: Function 用于计算得出相关值: Extend 有一批属性完全匹配时,应该使用extend

  7. [Sass] Level 4: Extend -- Ex

    Better use @extend with % placeholder. Extend is useful when you want to reuse some of you class. Al ...

  8. sass(混合mixin的调用、@content)

    sass中使用@mixin声明混合,可以传递参数,参数名以$符号开始,多个参数以逗号分开,也可以给参数设置默认值.声明的@mixin通过@include来调用 1.无参数mixin scss.styl ...

  9. CSS3与页面布局学习总结(七)——前端预处理技术(Less、Sass、CoffeeScript、TypeScript)

    CSS不像其它高级语言一样支持算术运算.变量.流程控制与面向对象特性,所以CSS样式较多时会引起一些问题,如修改复杂,冗余,某些别的语言很简单的功能实现不了等.而javascript则是一种半面向对象 ...

随机推荐

  1. jQuery学习总结2

    六.动画效果 6.1.基本 hide([speed,[fn]])隐藏显示的元素 speed: 三种预定速度之一的字符串("slow","normal", or ...

  2. codevs 2577 医院设置

    2577 医院设置 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold   题目描述 Description 设有一棵二叉树,如下图 其中,圈中数字表示结点居民的人口.圈边 ...

  3. bzoj 1176: [Balkan2007]Mokia&&2683: 简单题 -- cdq分治

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MB Description 你有一个N*N的棋盘,每个格子内有一个整数,初始时的时候全部为0,现在需要 ...

  4. UVALive 5058 Counting BST 数学

    B - Counting BST Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit S ...

  5. 《学习OpenCv》 笔记(1)

    P1-P17 废话 可跳过 不过讲了如何搭建环境,如果你没有搭建的话,可以查看我的另外一个博文,详细讲了如何构建OpenCv的编程环境 P19 开始编写第一个代码

  6. 编写简单登陆和注册功能的demo时遇到的问题

    一.注册功能中添加数据不成功 给数据库添加EditText中的内容后,数据库中找不到添加后的数据,并且存在字符串为空的数据 解决方法:EditText registerAccount = (EditT ...

  7. SmartProg2 Universal, ISP capable programmer

    http://www.elnec.com/products/universal-programmers/smartprog2/ 40 powerful TTL pindrivers provide H ...

  8. 百度地图api改变覆盖物背景实例及css颜色值简介

    在此鸣谢buptwusuopu的技术支持 在调用百度地图api的时候,为了改变覆盖物的颜色,如图中椭圆型的填充色.可以到百度api的库中查找方法http://developer.baidu.com/m ...

  9. Python中函数的参数传递与可变长参数

    转自旭东的博客原文 Python中函数的参数传递与可变长参数 Python中传递参数有以下几种类型: (1)像C++一样的默认缺省函数 (2)根据参数名传参数 (3)可变长度参数 示例如下: (1)默 ...

  10. Dictionary GetOrAdd

    public static TValue GetOrAdd<TKey,TValue>( this Dictionary<TKey,TValue> dictionary, TKe ...