阿里妈妈 @一丝 准备发布其CSSGrace,即CSS后处理插件,因而顺便聊聊CSS postprocessors。css
Rework是TJ大神开发的CSS预处理框架。但为何会出现呢?TJ大神如此回答:html
The simple answer is that Rework caters to a different audience, and provide you the flexibility to craft the preprocessor you want, not the choices the author(s) have force on you.
Our goal with Rework contrasts the others, as it does not provide a higher level language within the CSS documents, Rework’s goal is to make those constructs unnecessary, being the most transparent CSS pre-processor out there.前端
简单地说,就是从以前的特定CSS预处理器,转而成为通用式CSS预处理框架,经过插件,可自定义扩展功能。android
@include border-radius;
,可你知道compass这个mixin有啥问题么? .btn-default { -webkit-border-radius: 2px } // 仅在 android 2.1, chrome 4, ios_saf 3.2, safari 4 或更早期版本适用 .btn-default { -moz-border-radius: 2px } // 仅在 firefox 3.6 之前版本适用 .btn-default { -ms-border-radius: 2px } // 根本不存在 -ms-border-radius .btn-default { -o-border-radius: 2px } // 这玩意早就淘汰了
@include transition();
,但: .course-card .course-agency { -moz-transition: .3s } // 仅在 firefox 15 之前版本适用 .course-card .course-agency { -o-transition: .3s } // 仅在 opera 12 之前版本适用
在我看来真正带来革命的不是postcss,偏偏是他的核心组件Autoprefixer。让咱们看看他到底干了什么?ios
Working with Autoprefixer is simple: just forget about vendor prefixes and write normal CSS according to the latest W3C specs. You don’t need a special language (like Sass) or remember, where you must use mixins.
Just write normal CSS according to the latest W3C specs and Autoprefixer will produce the code for old browsers.git
因此呢?若是咱们写了:github
a { display: flex; }
则通过Autoprefixer,会变成:web
a { display: -webkit-box; display: -webkit-flex; display: -moz-box; display: -ms-flexbox; display: flex; }
而且这些hack数据是从caniuse获取的,因此能根据你的须要设置你须要兼容的浏览器。Sounds good!这更像polyfill,咱们只用按照标准写就行了,polyfill会帮忙处理兼容性,以后若是无需兼容,其会自动去除。chrome
Make it better!浏览器
CSSGrace在我看来主要因为AST的介入,其可能分析出之前preproccessors分析不出来的css错误问题,相似csslint的一些静态分析,以及一丝所说的CSS常见错误,例如:float: left/right 或者 position: absolute 后还写上 display: block,具体参见:http://www.zhihu.com/question/20979831
我的感受将来Web会Web Component化,不管是以W3C标准以HTML为核心的Web Component,仍是相似React以Javascript为核心的Web Component,在纵向力度足够细的时候,css样式将趋近与足够简单。
在这种背景下,当处理好做用域的状况下(目前没什么好办法,可能只能将class name写长一点),将来嵌套场景将大大减小,从这一点来看,之前的Sass、LESS等如此强大的预处理器未必是必需品。