postcss-cssnext
Version:
Use tomorrow’s CSS syntax, today
256 lines (248 loc) • 10.2 kB
Markdown
---
template: Simple
title: cssnext - Use tomorrow’s CSS syntax, today.
---
<div class="cssnext-Jumbotron cssnext-Jumbotron--default cssnext-Center cssnext-Light">
<section class="r-Grid">
<div class="r-Grid-cell">
<strong class="cssnext-Jumbotron-title">Use tomorrow’s CSS syntax, today.</strong>
<p>
<a
title="github.com/MoOx/postcss-cssnext"
href="https://github.com/MoOx/postcss-cssnext"
>
Check out postcss-cssnext on GitHub
</a>
or
<a href="/playground/">
try it in your browser
</a>
</p>
<iframe
frameborder="0" scrolling="0"
width="145px" height="30px"
style="vertical-align: middle"
src="https://ghbtns.com/github-btn.html?user=MoOx&repo=postcss-cssnext&type=star&count=true&size=large"
></iframe>
<script async src="//cdn.carbonads.com/carbon.js?zoneid=1673&serve=C6AILKT&placement=cssnextio" id="_carbonads_js"></script>
</div>
</section>
</div>
<section class="r-Grid cssnext-Section">
<div class="r-Grid-cell r-minM--1of3">
<h2 class="cssnext-Section-title">What is cssnext?</h2>
<p class="cssnext-Section-content">
PostCSS-cssnext is a <a href="https://github.com/postcss/postcss#readme">PostCSS</a>
plugin that helps you to use the latest CSS syntax today.
It transforms
<a href="http://www.xanthir.com/b4Ko0">new CSS specs</a>
into more compatible CSS
so you don't need to wait for browser support.
<em class="cssnext-Section-highlight">
You can literally write future-proof CSS
and forget old preprocessor specific syntax.
</em>
</p>
</div>
<div class="r-Grid-cell r-minM--2of3">
<h2 class="cssnext-Section-title"><a href="/features/">Features</a></h2>
<ul class="r-Grid cssnext-List cssnext-FeaturesList">
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#automatic-vendor-prefixes">automatic vendor prefixes</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#custom-properties-var">custom properties & <code>var()</code></a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#custom-properties-set-apply">custom properties set & <code>@apply</code></a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#reduced-calc">reduced <code>calc()</code></a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#custom-media-queries">custom media queries</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#media-queries-ranges">media queries ranges</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#custom-selectors">custom selectors</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#nesting">nesting</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#image-set-function"><code>image-set()</code> function</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#color-function"><code>color()</code> function</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#hwb-function"><code>hwb()</code> function</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#gray-function"><code>gray()</code> function</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#rrggbbaa-colors"><code>#rrggbbaa</code> colors</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#rgba-function-rgb-fallback"><code>rgba</code> function
<small class="cssnext-FeaturesList-small">
(<code>rgb</code> fallback</code>)
</small>
</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#rebeccapurple-color"><code>rebeccapurple</code> color</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#font-variant-property"><code>font-variant</code> property</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#filter-property"><code>filter</code> property</a>
<small class="cssnext-FeaturesList-small">
(svg fallback)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#initial-value"><code>initial</code> value</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#rem-unit-px-fallback"><code>rem</code> unit</a>
<small class="cssnext-FeaturesList-small">
(<code>px</code> fallback)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#any-link-pseudo-class"><code>:any-link</code> pseudo-class</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#matches-pseudo-class"><code>:matches</code> pseudo-class</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#not-pseudo-class"><code>:not</code> pseudo-class</a>
<small class="cssnext-FeaturesList-small">
(to l.3)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#pseudo-syntax-fallback"><code>::</code>pseudo syntax</a>
<small class="cssnext-FeaturesList-small">
(<code>:</code> fallback)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#overflow-wrap-property-word-wrap-fallback"><code>overflow-wrap</code> property</a>
<small class="cssnext-FeaturesList-small">
(<code>word-wrap</code> fallback)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#attribute-case-insensitive">attribute case insensitive</a>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#rgb-function-functional-notation"><code>rgb()</code> function</a>
<small class="cssnext-FeaturesList-small">
(functional-notation)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#hsl-function-functional-notation"><code>hsl()</code> function</a>
<small class="cssnext-FeaturesList-small">
(functional-notation)
</small>
</li>
<li class="r-Grid-cell r-minS--1of2">
<a href="/features/#system-ui-font-family"><code>system-ui</code> font-family</a>
<small class="cssnext-FeaturesList-small">
(font-family fallback)
</small>
</li>
</ul>
<small
class="cssnext-FeaturesList-small"
style="display: block; text-align: center;"
>
<small>
<em>l.* are level of the specification (when information is relevant)</em>
</small>
</small>
</div>
</section>
<section class="cssnext-Jumbotron cssnext-Jumbotron--whiteRoad">
<div class="r-Grid cssnext-Center">
<div class="r-Grid-cell r-minM--1of2 cssnext-Section">
<h2 class="cssnext-Section-title">Why cssnext?</h2>
<p class="cssnext-Section-content" style="text-align: left">
Prior to 2015, CSS was frustrating by not having any specification for features we were looking for.
No variables, no math, no color manipulation & no customization.
Things are going to change soon since a lot of work has been made by the W3C to write new specs to make our life easier.
With cssnext, you can start using some new features today!
</p>
</div>
</div>
</section>
<section class="cssnext-Jumbotron cssnext-Jumbotron--darkDeloreanFront cssnext-Light">
<div class="r-Grid">
<div class="r-Grid-cell r-minM--1of2 cssnext-Section">
<h3 class="cssnext-Section-title">Future-proof code</h3>
<p class="cssnext-Section-content">
In a near future, browsers will implement new CSS specifications. As time passes, cssnext will remove some transformations that won't be necessary anymore.
And maybe one day, you will be able to completely remove cssnext from your workflow without touching your CSS.
</p>
</div>
</div>
</section>
<section class="cssnext-Jumbotron cssnext-Jumbotron--lightFast">
<div class="r-Grid">
<div class="r-Grid-cell r-minM--1of2"></div>
<div class="r-Grid-cell r-minM--1of2 cssnext-Section">
<h3 class="cssnext-Section-title">It's fast. Lightning fast.</h3>
<p class="cssnext-Section-content">
cssnext uses <a href="https://github.com/postcss/postcss">PostCSS</a>
which has
<a href="https://github.com/postcss/benchmark">a way faster CSS parser</a>.
<br />
It's a good competitor to libsass, a bit faster than LESS and Stylecow,
and way faster than Myth or original Ruby Sass.
</p>
</div>
</div>
</section>
<div class="cssnext-Jumbotron cssnext-Jumbotron--default cssnext-Center cssnext-Light">
<section class="r-Grid">
<div class="r-Grid-cell">
<div class="cssnext-Jumbotron-title">
<a href="/playground/">Try postcss-cssnext in your browser now.</a>
</div>
</div>
</section>
</div>
<section class="cssnext-Jumbotron cssnext-Center">
<div class="r-Grid">
<div class="r-Grid-cell">
Follow
<a href="https://twitter.com/cssnext">@cssnext</a>
to get the latest news
or
<a href="https://gitter.im/MoOx/postcss-cssnext">join the chat on gitter</a>
if you have any questions.
</div>
</div>
</section>
<div class="cssnext-Jumbotron cssnext-Jumbotron--cssrecipes cssnext-Center cssnext-Light">
<section class="r-Grid">
<div class="r-Grid-cell">
<div class="cssnext-Jumbotron-title cssnext-Jumbotron-title--smaller">
<a href="https://cssrecipes.github.io/">Check out cssrecipes, components working with cssnext</a>
</div>
<small>
You can also check
<a href="https://suitcss.github.io/">suitcss</a>
or
<a href="http://www.basscss.com/">basscss</a>
</small>
</div>
</section>
</div>