Cómo migrar del framework Materialize CSS a Stylify CSS
Esta guía está aquí para ayudarte a comparar rápidamente las características y sintaxis del framework de componentes Materialize con las del CSS utility-first de Stylify, y darte una idea de cómo migrar de Materialize a Stylify.
Introducción
Materialize es un moderno marco de front-end responsivo basado en Material Design
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
Materialize proporciona un montón de utilidades para propiedades como colores, tipografía, rejillas, etc:
<span class="blue-text text-darken-2">Este es un panel de tarjeta con texto azul oscuro</span>
<div class="row">
<div class="col s1">1</div>
<div class="col s1">2</div>
</div>
<p class="flow-text">Soy Flow Text</p>
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 Materialize 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
Materialize es un framework basado en componentes. Por lo tanto, hay un montón de componentes, como botones, insignias, formularios, tablas, menús, etc:
<span class="badge">1</span>
<a class="btn-floating btn-large waves-effect waves-light red">
<i class="material-icons">añadir</i>
</a>
<ul class="pagination">
<li class="disabled"><a href="#!"><i class="material-icons">chevron_left</i></a></li>
<li class="active"><a href="#!">1</a></li>
<li class="waves-effect"><a href="#!">2</a></li>
<li class="waves-effect"><a href="#!">3</a></li>
<li class="waves-effect"><a href="#!"><i class="material-icons">chevron_right</i></a></li>
</ul>
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
Materialize CSS se puede configurar modificando los archivos SCSS descargados y generando un nuevo tema durante un proceso de compilación.
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.