Windi CSS for Gatsby
npm install gatsby-plugin-windicssWindi CSS for Gatsby, it's fast! ⚡️
a.k.a On-demand Tailwind CSS
⚡️ See speed comparison with Tailwind
- ⚡️ It's FAST - 20~100x times faster than tailwindcss
- 🧩 On-demand CSS utilities (Compatible with Tailwind CSS v2) and native elements style resetting
- 🍃 Load configurations from tailwind.config.js
- 📄 CSS @apply / @screen directives in any file: Vue SFC, Less, SCSS, SASS, PostCSS, Stylus
- 🎳 Support Utility Groups - e.g. bg-gray-200 hover:(bg-gray-100 text-red-300)
``bash`
yarn add windicss gatsby-plugin-windicssnpm i windicss gatsby-plugin-windicss
:warning: This module is a pre-release, please report any issues you find.
Within your gatsby-config.js add the following.
`jsgatsby-plugin-windicss
// gatsby-config.js
module.exports = {
// ...
plugins: [
{
resolve: ,`
options: {
// see https://github.com/windicss/vite-plugin-windicss/blob/main/packages/plugin-utils/src/options.ts
},
},
],
};
This module won't work with tailwindcss, you will need to remove it.
`diffgatasby-plugin-postcss
plugins: [
{
resolve: ,`
options: {
// ...
- require("tailwindcss"),
// ...
},
},
],
If you have a tailwind.config.js, please rename it to windi.config.js or windi.config.ts.
See here for configuration details.
If you were previously using tailwindcss, please consult the documentation on migrating.
- Default:
`js`
export default {
scan: {
exclude: ["node_modules", ".git", "dist", "public", ".cache", ".temp"],
},
transformCSS: "pre",
};
- See options.ts for configuration reference.
#### Disable Preflight
_gatsby-config.js_
`jsgatsby-plugin-windicss
// gatsby-config.js
module.exports = {
// ...
plugins: [
{
resolve: ,`
options: {
preflight: false,
},
},
],
};
@media directive with scoped style can only work with css postcss scss but not sass, less nor stylus`
- Windy team
- @antfu Based on his Rollup / Vite implementation & his util package
MIT License © 2021 blackcater