Cómo migrar del framework CSS Tailwind Utility-First 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 Tailwind con las de Stylify, y darte una idea de cómo migrar de Tailwind 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

Tailwind es una librería que te ayuda a construir rápidamente sitios web modernos sin salir de tu HTML. Es un framework CSS que prioriza la utilidad y está repleto de clases como flex, pt-4, text-center y rotate-90 que se pueden componer para construir cualquier diseño, directamente en tu marcado.

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

Tailwind proporciona un montón de utilidades CSS flexibles para propiedades como color, espaciado, tipografía, visibilidad, etc:

<div class="
	bg-slate-100
	rounded-xl
	p-8
	top-[117px]
	md:flex
"></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

Cuando quieras seleccionar por ejemplo elementos hijo en Tailwind, puedes usar variantes arbitrarias para ello:

<div class="
	[&>*]:underline
	[&>p]:mt-0
"></div>

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

Los componentes en Tailwind se pueden definir usando la regla @apply. También se pueden anidar en capas CSS:

@layer components {
	.btn-primary {
		@apply py-2 px-4 bg-blue-500 text-white;
	}
}

Tailwind también proporciona un montón de componentes copy&paste en su web.

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

Tailwind se puede configurar dentro de un archivo de configuración extendiendo/sobrescribiendo un tema existente:

module.exports = {
	content: ['./src/**/*.{html,js}'],
	theme: {
		colors: {
			'blue': '#1fb6ff',
		},
		fontFamily: {
			sans: ['Graphik', 'sans-serif'],
		},
		extend: {
			spacing: {
				'8xl': '96rem',
				'9xl': '128rem',
			},
			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.