Cómo migrar de Windi utility-first CSS framework a Stylify CSS
Esta guía está aquí para ayudarte a comparar rápidamente las características y sintaxis del framework CSS utility-first de Windi con las de Stylify, y darte una idea de cómo migrar de Windi a Stylify.
Introducción
Windi CSS es una alternativa bajo demanda a Tailwind, que proporciona tiempos de carga más rápidos, compatibilidad total con Tailwind v2.0, y un montón de características adicionales interesantes.
Stylify CSS es una librería que usa selectores nativos tipo CSS color:blue
, max-width:640px
, margen:0_auto
junto con variables, componentes, selectores personalizados para generar CSS optimizado dinámicamente basado en lo que escribes.
Selectores y utilidades CSS
En Windi, puedes usar utilidades directamente sobre el elemento. Los selectores (grupos) también pueden contener un espacio:
<div class="
py-8 px-8 max-w-sm mx-auto
sm:(py-4 flex items-center space-y-0 space-x-6)
">
</div>
Stylify utiliza utilidades similares a CSS, que se pueden utilizar directamente dentro del atributo class. No hay atajos por defecto y los selectores no pueden contener un espacio debido a la mayor optimización.:
<div class="
color:blue
font-weight:bold
md:color:red
md&&landscape:font-size:32px
minw123px:font-size:123px
"></div>
Cuando algunos selectores tienen la misma pseudo-clase o incluso media query, puedes agruparlos así:
<div class="
hover:{color:blue;text-decoration:underline}
md:hover:{transform:scale(1.1);left:4px}
"></div>
Selectores globales
No he podido encontrar ninguna información que sugiera que Windi proporcione algo parecido a Selectores Globales dinámicos.
Stylify proporciona selectores personalizados con los que puedes aplicar estilo a los elementos de forma global. Estos selectores pueden ser definidos directamente dentro del atributo class o en el config global o en un archivo donde se usan usando opciones de contenido.
Ejemplo con el atributo class:
<div class="[.button_.icon]{font-size:14px}">
<button class="
[.icon]{color:#fff;border-radius:12px}
[&+button]{margin-left:24px}
">
<i class="icon"></i>
</button>
<button></button>
<div>
El patrón sintáctico en el atributo class tiene este aspecto:
[css selectors]{stylify selectors split by ;}
El _
(guión bajo) se utiliza en lugar del espacio tanto en selectores CSS como Stylify y el carácter &
siempre se refiere al elemento actual.
El mismo código pero en la configuración global se vería así:
const compilerConfig = {
customSelectors: {
'.buttons-wrapper .button .icon': 'font-size:14px',
'.button': `
.icon { color:#fff border-radius:12px }
& + button { margin-left:24px }
`,
}
}
Al definir `customSelectors` en la configuración global a través de opciones de contenido, la sintaxis permite utilizar una característica de anidamiento. Los caracteres &
se refieren al nivel superior como en el SCSS.
Uso de la config global:
<div class="buttons-wrapper">
<button class="button">
<i class="icon"></i>
</button>
<button></button>
<div>
Componentes
En Windi, los componentes se definen dentro de un plugin así:
import plugin from 'windicss/plugin'
plugin(({ addComponents }) => {
addComponents({
'.btn': {
padding: '.5rem 1rem',
borderRadius: '.25rem',
},
})
})
También puedes definir un atajo:
export default {
shortcuts: {
'btn': {
'color': 'white',
'@apply': 'py-2 px-4 font-semibold rounded-lg',
'&:hover': {
'@apply': 'bg-green-700',
'color': 'black',
},
},
},
}
Stylify no proporciona ningún CSS predefinido Componentes por defecto. Sin embargo, proporciona dos maneras de definirlos y hay un conjunto de copiar y pegar Componentes sin cabeza que puede utilizar en su proyecto.
Los componentes pueden ser configurados en un archivo (usando opciones de contenido), donde son usados, o globalmente dentro de un $projectConfig.
Ejemplo con la configuración dentro de un archivo. El contenido entre stylify-components
espera objeto javascript sin corchetes circundantes:
<!--
stylify-components
title: 'color:blue font-weight:bold md:color:red'
/stylify-components
-->
<h1 class="title"></h1>
Ejemplo en un config global del compilador:
const compilerConfig = {
components: {
title: 'color:blue font-weight:bold md:color:red'
}
};
Uso:
<h1 class="title"></h1>
Cuando se define un componente, también se puede utilizar la sintaxis de anidamiento como en SCSS. Esto funciona en una configuración global y también en las opciones de contenido:
const compilerConfig = {
components: {
button: `
color:black font-weight:bold
&:hover { color:grey }
&--red {
color:red
&:hover { color: darkred }
}
`
}
};
Configuración, personalización y variables
En Windi se configura un tema en el archivo config.
import { defineConfig } from 'windicss/helpers'
import colors from 'windicss/colors'
import plugin from 'windicss/plugin'
export default defineConfig({
darkMode: 'class',
theme: {
extend: {
screens: {
'sm': '640px',
},
colors: {
blue: colors.sky,
},
fontFamily: {
sans: ['Graphik', 'sans-serif'],
},
spacing: {
128: '32rem',
},
borderRadius: {
'4xl': '2rem',
},
},
},
})
En Stylify, no hay nada como un "tema", ni extender sección en $projectConfig. Sólo hay variables.
Las variables se pueden definir de dos formas en Stylify. En una configuración global o dentro de un archivo donde se utilizan a través de opciones de contenido.
Ejemplo con config global:
const compilerConfig = {
variables: {
primary: '#000',
secondary: '#eee',
titleFontSize: '24px',
shadow: '0 2px 3px #000'
}
}
También se pueden definir variables basadas en media query:
const compilerConfig = {
variables: {
dark: { blue: 'lightblue' },
md: { fontSize: 24px },
'minw640px': { fontSize: 32px },
// When screen is not found, it falls back to a random custom selector
'.dark': { blue: 'lightblue' },
':root[data-theme="dark"]': { blue: 'lightblue' }
}
}
Ejemplo con opciones de contenido:
<!--
stylify-variables
primary: '#000',
secondary: '#eee'
titleFontSize: '24px',
shadow: '0 2px 3px #000'
/stylify-variables
-->
<div class="color:$primary"></div>
Integra Stylify en tu herramienta favorita
Stylify puede ser usado en varias herramientas. Elige tu herramienta favorita y empieza a usar Stylify CSS en un minuto
Empieza
- 🚀 Aprende cómo empezar
- 🔌 Echa un vistazo a configuración de @stylify/unplugin
- ⚙️ O configura Stylify directamente:
Acelera el desarrollo con componentes CSS Headless preparados
Copiar&Pegar, componentes sin estilo inspirados en el Material Design V3.