Cómo migrar de Bulma CSS framework a Stylify CSS

Esta guía está aquí para ayudarte a comparar rápidamente las características y sintaxis del framework de componentes Bulma con las del CSS utility-first de Stylify, y darte una idea de cómo migrar de Bulma 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

Bulma es un framework gratuito y de código abierto que proporciona componentes frontend listos para usar que puedes combinar fácilmente para construir interfaces web responsivas.

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

Bulma proporciona utilidades CSS para propiedades como color, espaciado, tipografía, visibilidad, etc:

<div class="
	has-text-white
	mb-4 px-1
	is-capitalized
"></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 Bulma proporciona algo así como 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

Bulma es un framework basado en componentes. Por lo tanto, hay un montón de componentes, como botones, insignias, formularios, tablas, menús, etc:

<input class="input is-primary">
<aside class="menu">
	<p class="menu-label">General</p>
	<ul class="menu-list">
		<li><a>Panel de control</a></li>
	</ul>
</aside>

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

Bulma se configura a través de variables SCSS dentro de un archivo de importación y el tema se genera durante un proceso de construcción:

// Configura los colores de tu marca
$purple: #8A4D76;
// ...

// Actualiza las variables globales de Bulma
$family-sans-serif: "Nunito", sans-serif;
// ...

// Actualizar algunas variables de los componentes de Bulma
$body-background-color: $beige-lighter;
// ...

// Importa sólo lo que necesites de Bulma
@import "../node_modules/bulma/sass/utilities/_all.sass";
@import "../node_modules/bulma/sass/base/_all.sass";
// ...

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.