Download create-next-app
to bootstrap the example:
npm i -g create-next-app
create-next-app --example with-styled-jsx-plugins with-styled-jsx-plugins-app
Download the example or clone the repo:
curl https://codeload.github.com/zeit/next.js/tar.gz/canary | tar -xz --strip=2 next.js-canary/examples/with-styled-jsx-plugins
cd with-styled-jsx-plugins
Install it and run:
npm install
npm run dev
Deploy it to the cloud with now (download)
now
Next.js ships with styled-jsx allowing you to write scope styled components with full css support. This is important for the modularity and code size of your bundles and also for the learning curve of the framework. If you know css you can write styled-jsx right away.
This example shows how to configure styled-jsx to use external plugins to modify the output. Using this you can use PostCSS, SASS (SCSS), LESS, or any other pre-processor with styled-jsx. You can define plugins in .babelrc
. In this case PostCSS was used as an example. PostCSS plugins are defined in package.json
.
More details about how plugins work can be found in the styled-jsx readme