cssnext 语法说明

支持书写CSS未来语法的插件,文章整理了支持PostCSS的常用语法

  • 自定义属性 & var()
  • 自定义属性集 & @apply
  • calc() & var()
  • 媒体查询 & @custom-media
  • 自定义选择器 & @custom-selector
  • 嵌套 & &
  • color()

自定义属性 & var()

:root{} 中定义常用属性,使用--前缀命名变量
使用 var() 调用

:root{
    --mainColor: red;
}

a{
    color: var(--mainColor);
}

编译后样式

a{
    color: red;
}

自定义属性集 & @apply

:root{} 中定义属性集,使用 -- 前缀命名属性集变量名
使用 @apply 进行调用
http://cssnext.io/playground/ 在线测试有效

:root {
  --centered: {
    display: flex;
    align-items: center;
    justify-content: center;
  };
}

.centered {
  @apply --centered;
}

编译后样式

.centered {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

calc() & var()

使自定义属性支持 calc()

:root{
    --fontSize: 1rem;
}
h1{
    font-size: calc(var(--fontSize)*2);
}

编译后样式

h1{
    font-size: calc(1rem*2);
}

媒体查询 & @custom-media

支持使用<=,>=;代码在css最后
注意:变量名和括号之间保留空格

@custom-media --small-viewport (max-width: 30em);
@media (--small-viewport){
    body { font-size: 10rem;}
}

编译后样式

@media (max-width: 30em){
    body{
        font-size: 10rem;
    }
}

@custom-media --viewport-medium (width <= 50rem);
@media (--viewport-medium) {
body { font-size: calc(var(--fontSize) * 1.2); }
}

编译后样式

@media (max-width: 50rem){
    body{
        font-size: calc(1rem * 1.2);
    }
}

@media (width >= 500px) and (width <= 1200px){
    body{
        width: 100%;
    }
}

编译后结果

@media (min-width: 500px) and (max-width: 1200px){
    body{
        width: 100%;
    }
}

自定义选择器 & @custom-selector

@custom-selector :--button button, .button;
@custom-selector :--enter :hover, :focus;
@custom-selector :--heading h1, h2, h3, h4, h5, h6;

:--button{
    box-shadow: 0 0 1px black;
}

a:--enter{
    color: black;
}

:--heading { 
    margin-top: 0;
}

编译后样式

button, .button{
    box-shadow: 0 0 1px black;
}

a:hover, a:focus{
    color: black;
}

h1, h2, h3, h4, h5, h6 { 
    margin-top: 0;
}

嵌套 & &

@nest selector & 外层嵌套
支持嵌套媒体查询

a{
    & span{
        color: white;
    }
    
    @nest span &{
        color: blue;
    }
    /*嵌套@media*/
    @media (min-width: 30rem){
        color: yellow;
    }
}

编译后样式

a{
}

a span{
    color: white;
}

span a{
    color: blue;
}

@media (min-width: 30em) {
    a{
        color: yellow
    }
}

color()

更多颜色修饰:https://github.com/postcss/postcss-color-function#list-of-color-adjuster

a{
    color: color(red alpha(-10%));
}

a:hover{
    color: color(red blackness(80%));
}

编译后样式

a{
    color: #ff0000;
    color: rgba(255, 0, 0, 0.9);
}
a:hover{
    color: rgb(51, 0, 0);
}

更多语法规则:http://cssnext.io/
文章源码下载:https://github.com/NalvyBoo/PostCSS-Comn/tree/master/cssnext

你可能感兴趣的:(cssnext 语法说明)