V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Can I use?
http://caniuse.com/
Less
http://lesscss.org
Cool Libraries
Bootstrap from Twitter
Jetstrap
bukas
V2EX  ›  CSS

useful sass mixins

  •  
  •   bukas ·
    huanz · 2016-09-17 13:55:20 +08:00 · 3266 次点击
    这是一个创建于 3021 天前的主题,其中的信息可能已经有所发展或是发生改变。

    mixins https://github.com/huanz/mixins

    sass mixins , require Sass ~> 3.3.0

    utility

    functions

    string

    list

    install

    npm i mixins-sass --save
    

    utility

    prefix

    // scss 默认前缀: webkit moz ms o
    .test {
        @include prefix((transliton: all 0.5s ease-out), webkit);
    }
    // css
    .test {
        -webkit-transliton: all 0.5s ease-out;
        transliton: all 0.5s ease-out;
    }
    

    clearfix

    @include clearfix;
    

    float

    @include float(left);
    

    text-overflow

    文字超出显示省略号,支持多行,$substract为预留区域百分比%

    @mixin text-overflow($line: 1, $substract: 0);
    

    animation

    @include animation(slideUp 900ms ease both) {
        0% {
            transform: translate3d(0, -200px, 0);
        }
        100% {
            transform: translate3d(0, 0, 0);
        }
    }
    

    placeholder

    // scss
    @include placeholder() {
        ...
    }
    // css
    ::-webkit-input-placeholder {
        ...
    }
    ::-moz-placeholder {
        ...
    }
    :-ms-input-placeholder {
       ...
    }
    

    rem

    px 转 rem

    // @mixin rem($property, $values, $support-ie: true, $base: null)
    // $support-ie 不支持 rem 的浏览器使用 px
    // $base 如果未传,会搜索全局变量 $base-font ,如果没有默认为 16px
    @include rem('padding', '10px 5px 5px 10px', true, '16px');
    

    opacity

    兼容 ie 的透明度

    arrow

    生成上下左右的小箭头:http://lugolabs.com/caret

    // @mixin arrow($width, $border-width, $direction, $color, $background-color, $position: relative)
    // 箭头宽度  线宽 方向 颜色 背景颜色(一般和父级背景同色)
    @include arrow(10px, 1px, 'bottom', '#00f', '#fff');
    

    triangle

    三角形生成

    // @mixin triangle($width, $height, $color: #000, $direction: down)
    @include triangle(10px, 5px);
    

    center

    居中

    // horizontal,vertical,both
    @include center(both);
    

    media

    媒体查询相关

    // min-width max-width
    @mixin screen($min, $max)
    @mixin max-screen($width)
    @mixin min-screen($width)
    @mixin hidpi($ratio: 1.3)
    @mixin retina-image($filename, $retina-filename, $ratio: 1.3, $background-size: 100%)
    @mixin iphone6($orientation: all)
    @mixin iphone6plus($orientation: all)
    @mixin iphone5($orientation: all)
    @mixin iphone4($orientation: all)
    @mixin ipad($orientation: all)
    @mixin ipad-mini($orientation: all)
    @mixin ipad-retina($orientation: all)
    @include retina-image(test.png, [email protected] [email protected], 2 3);
    

    box-sizing

    html {
        @include box-sizing(border-box);
    }
    

    touch-scroll

    body {
        @include touch-scroll;
    }
    // css
    body {
        -webkit-overflow-scrolling: touch;
        overflow-scrolling: touch;
    }
    

    font

    中文字体解决方案,来自https://github.com/zenozeng/fonts.css,有font-heifont-kaifont-songfont-fang-song

    body {
        @include font-hei;
    }
    

    functions

    string

    str-split

    字符串分隔

    @function str-split($string, $delimiter: " ")
    

    str-repeat

    字符串重复

    @function str-repeat($string, $times)
    

    str-replace

    字符串替换

    @function str-replace($string, $search, $replace: "")
    

    list

    first

    返回列表第一项

    @function first($list)
    

    last

    返回列表最后一项

    @function last($list)
    

    prepend

    向列表前面插入一个

    @function prepend($list, $value)
    

    insert-nth

    向列表某个位置插入

    @function insert-nth($list, $index, $value)
    

    replace

    替换列表的某个元素 $recursive 是否全部替换

    @function replace($list, $old-value, $new-value, $recursive: false)
    

    replace-nth

    替换列表某个位置的元素

    @function replace-nth($list, $index, $value)
    

    remove

    删除列表某个元素 $recursive 是否删除所有

    @function remove($list, $value, $recursive: false)
    

    remove-nth

    删除列表指定位置元素

    @function remove-nth($list, $index)
    

    slice

    截取列表中的一部分

    @function slice($list, $start: 1, $end: length($list))
    

    to-string

    列表变成字符串,$glue为连接符,$is-nested是否是嵌套的列表

    @function to-string($list, $glue: '', $is-nested: false)
    

    shift

    将列表部分元素前置

    @function shift($list, $index: 1)
    
    1 条回复    2016-09-17 14:09:33 +08:00
    yangg
        1
    yangg  
       2016-09-17 14:09:33 +08:00
    why not http://bourbon.io/ and autoprefixer?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1035 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 19:51 · PVG 03:51 · LAX 11:51 · JFK 14:51
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.