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.

Si encuentras alguna información incorrecta o que falta, por favor contacta con <a href="mailto:dev@stylifyccss.com">dev@stylifycss.com</a> o edita esta página en Github.

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

Acelera el desarrollo con componentes CSS Headless preparados

Copiar&Pegar, componentes sin estilo inspirados en el Material Design V3.