Migrando desde Gatsby
Aquí hay algunos conceptos clave y estrategias de migración para ayudarte a comenzar. ¡Utiliza el resto de nuestra documentación y nuestra comunidad en Discord para seguir adelante!
Principales similitudes entre Gatsby y Astro
Sección titulada Principales similitudes entre Gatsby y AstroGatsby y Astro comparten algunas similitudes que te ayudarán a migrar tu proyecto:
-
La sintaxis de los archivos
.astro
es similar a JSX. Escribir en Astro debería sentirse familiar. -
Astro has built-in support for Markdown and an integration for using MDX files. Also, you can configure and continue to use many of your existing Markdown plugins.
-
Astro también cuenta con una integración oficial para usar componentes de React. Ten en cuenta que en Astro, los archivos de React deben tener una extensión
.jsx
o.tsx
. -
Astro tiene soporte para instalar paquetes de NPM, incluyendo bibliotecas de React. Muchas de tus dependencias existentes funcionarán en Astro.
-
Al igual que en Gatsby, los proyectos de Astro pueden SSG o SSR con prerrenderizado a nivel de página.
Principales diferencias entre Gatsby y Astro
Sección titulada Principales diferencias entre Gatsby y AstroCuando reconstruyes tu sitio de Gatsby en Astro, notarás algunas diferencias importantes:
-
Los proyectos de Gatsby son aplicaciones de una sola página (SPA) de React y utilizan
index.js
como raíz del proyecto. Los proyectos de Astro son sitios multipágina yindex.astro
es tu página de inicio. -
Componentes Astro No se escriben como funciones exportadas que devuelven plantillas de páginas. En su lugar, dividirás tu código en un “bloque de codigo” para tu JavaScript y un cuerpo exclusivamente para el HTML que generes.
-
Datos de archivos locales: Gatsby utiliza GraphQL para recuperar datos de los archivos de tu proyecto. Astro utiliza importaciones de ESM y funciones de espera en el nivel superior (p. ej.
Astro.glob()
,getCollection()
) para importar datos de los archivos de tu proyecto. Puedes agregar manualmente GraphQL a tu proyecto de Astro, pero no está incluido de forma predeterminada.
Convierte tu proyecto de Gatsby
Sección titulada Convierte tu proyecto de GatsbyCada migración de proyecto será diferente, pero hay algunas acciones comunes que realizarás al convertir de Gatsby a Astro.
Crear un nuevo proyecto de Astro
Sección titulada Crear un nuevo proyecto de AstroUtiliza el comando create astro
en tu gestor de paquetes para iniciar el asistente de línea de comandos de Astro o elige un tema de la comunidad desde el Catálogo de Temas de Astro.
Puedes pasar el argumento --template
al comando create astro
para iniciar un nuevo proyecto de Astro con uno de nuestros inicios oficiales (p. ej. docs
, blog
, portfolio
). Alternativamente, puedes iniciar un nuevo proyecto a partir de cualquier repositorio de Astro existente en GitHub.
A continuación, copia los archivos de tu proyecto de Gatsby existente a tu nuevo proyecto de Astro en una carpeta separada fuera de src
.
Visita https://astro.new para obtener la lista completa de plantillas de inicio oficiales, y enlaces para abrir un nuevo proyecto en StackBlitz, CodeSandbox o Gitpod.
Instalar integraciones (opcional)
Sección titulada Instalar integraciones (opcional)Puede resultarte útil instalar algunas de las integraciones opcionales de Astro para utilizar durante la conversión de tu proyecto de Gatsby a Astro:
-
@astrojs/react: para reutilizar algunos componentes UI de React existentes en tu nuevo sitio Astro o seguir escribiendo con componentes de React.
-
@astrojs/mdx: para llevar los archivos MDX existentes de tu proyecto de Gatsby o utilizar MDX en tu nuevo sitio Astro.
Pon tu código en src
Sección titulada Pon tu código en srcSiguiendo la estructura de proyecto de Astro:
-
Elimina la carpeta
public/
de Gatsby.Gatsby utiliza el directorio
public/
dpara la salida de compilación, por lo que puedes descartar de forma segura esta carpeta. Ya no necesitarás una versión compilada de tu sitio de Gatsby. (Astro utilizadist/
de forma predeterminada para la salida de compilación) -
Renombra la carpeta
static/
de Gatsby apublic/
, y úsala como la carpetapublic/
de Astro.Astro utiliza una carpeta llamada
public/
para los activos estáticos. Como alternativa, puedes copiar el contenido destatic/
ien la carpetapublic/
existente de Astro. -
Copia o mueve los otros archivos y carpetas de Gatsby (p. ej.
components
,pages
, etc.) según sea necesario en tu carpetasrc/
de Astro a medida que reconstruyes tu sitio, siguiendo la estructura de proyecto de Astro.
La carpeta src/pages/
de Astro es una carpeta especial utilizada para la creación de páginas y publicaciones de tu sitio mediante enrutamiento basado en archivos a partir de archivos .astro
, .md
y .mdx
. No será necesario configurar ningún comportamiento de enrutamiento para tus archivos Astro, Markdown y MDX en Astro.
Todas las demás carpetas son opcionales y puedes organizar el contenido de tu carpeta src/
de la forma que desees. Otras carpetas comunes en proyectos de Astro incluyen src/layouts/
, src/components
, src/styles
, y src/scripts
.
Consejos: Convierte archivos JSX a archivos .astro
Sección titulada Consejos: Convierte archivos JSX a archivos .astroAquí tienes algunos consejos para convertir un componente de Gatsby con extensión .js
a un componente .astro
:
-
Utiliza únicamente el bloque
return()
de la función del componente de Gatsby existente como tu plantilla HTML en Astro. -
Cambia cualquier sintaxis de Gatsby o JSX a la sintaxis de Astro o a los estándares web de HTML. Esto incluye
<Link to="">
,{children}
, yclassName
, por ejemplo. -
Mueve cualquier JavaScript necesario, incluyendo las declaraciones de importación, a un “bloque de código” (
---
). Nota: JavaScript para renderizar contenido condicionalmente a menudo se escribe directamente dentro de la plantilla HTML en Astro. -
Utiliza
Astro.props
para acceder a cualquier prop adicional que se haya pasado previamente a tu función de Gatsby. -
Decide si también es necesario convertir a Astro los componentes importados. Con la integración oficial de React instalada, puedes utilizar los componentes de React existentes en tus archivos de Astro](/es/guides/framework-components/). Sin embargo, es posible que desees convertirlos en componentes
.astro
, ¡especialmente si no necesitan ser interactivos! -
Elimina cualquier consulta de GraphQL. En su lugar, utiliza declaraciones de importación y
Astro.glob()
para realizar consultas en tus archivos locales.
Consulta un ejemplo de la plantilla de inicio del blog de Gatsby convertido paso a paso
Comparación: .jsx
vs .astro
Sección titulada Comparación: .jsx vs .astroCompara el siguiente componente de Gatsby con su equivalente en Astro:
Migrando archivos de diseño
Sección titulada Migrando archivos de diseñoPuede resultarte útil comenzar convirtiendo tus diseños y plantillas de Gatsby en componentes de diseño de Astro.
Cada página en Astro requiere explícitamente las etiquetas <html>
, <head>
, y <body>
para estar presentes, por lo que es común reutilizar un archivo de diseño en varias páginas. Astro utiliza un elemento <slot />
en lugar de la prop {children}
de React para el contenido de la página, y no se requiere ninguna declaración de importación. Tus archivos layout.js
y plantillas de Gatsby no incluirán esto.
Ten en cuenta la plantilla HTML estándar y el acceso directo a <head>
:
También puedes reutilizar el código del archivo src/components/seo.js
de Gatsby para incluir metadatos adicionales del sitio. Observa que Astro no utiliza ni <Helmet>
ni <Header>
sino que crea <head>
directamente. Puedes importar y utilizar componentes, incluso dentro de <head>
, para separar y organizar el contenido de tu página.
Migrando páginas y publicaciones
Sección titulada Migrando páginas y publicacionesEn Gatsby, tus páginas y publicaciones pueden existir en src/pages/
o fuera de src
en otra carpeta, como content
. En Astro, todo el contenido de tu página debe estar dentro de src/
.
Páginas de React
Sección titulada Páginas de ReactTus páginas existentes de Gatsby en formato JSX (.js
) deberán ser convertidas de archivos JSX a páginas .astro
. No puedes utilizar un archivo de página JSX existente en Astro.
Estas páginas .astro
deben estar ubicadas dentro de src/pages/
y tendrán rutas de página generadas automáticamente en función de la ruta de su archivo.
Páginas Markdown y MDX
Sección titulada Páginas Markdown y MDXAstro tiene soporte integrado para Markdown y una integración opcional para archivos MDX. Tus archivos existentes de Markdown y MDX pueden ser reutilizados, pero pueden requerir algunos ajustes en su frontmatter, como agregar la propiedad especial de frontmatter de Astro layout
. TTambién puedes colocarlos dentro de src/pages/
para aprovechar el enrutamiento automático basado en archivos.
Alternativamente, puedes utilizar colecciones de contenido en Astro para almacenar y gestionar tu contenido. Cuando forman parte de una colección, los archivos Markdown y MDX estarán ubicados en carpetas dentro de src/content/
. Deberás recuperar el contenido tú mismo y generar esas páginas dinámicamente.
Migrando Tests
Sección titulada Migrando TestsAstro genera HTML sin procesar, lo que permite escribir pruebas de extremo a extremo utilizando la salida del paso de construcción. Es posible que las pruebas de extremo a extremo escritas previamente funcionen sin problemas si has logrado igualar el marcado del sitio antiguo de Gatsby. Puedes importar y utilizar bibliotecas de pruebas como Jest y React Testing Library en Astro para probar tus componentes de React.
Consulta la guía de testing de Astro para obtener más información.
Reutilizar archivos de configuración
Sección titulada Reutilizar archivos de configuraciónGatsby tiene varios archivos de configuración de nivel superior que también incluyen metadatos del sitio y de las páginas, y se utilizan para el enrutamiento. No utilizarás ninguno de estos archivos gatsby-*.js
en tu proyecto de Astro, pero es posible que haya algún contenido que puedas reutilizar a medida que construyas tu proyecto de Astro.
-
gatsby-config.js
: Mueve tusiteMetadata: {}
asrc/data/siteMetadata.js
(ositeMetadata.json
) para importar datos sobre tu sitio (title, description, social accounts, etc.) en las plantillas de página. -
gatsby-browser.js
: Considera agregar cualquier cosa utilizada aquí directamente en la etiqueta<head>
de tu diseño principal. -
gatsby-node.js
: No necesitarás crear tus propios nodos en Astro, pero ver el esquema en este archivo puede ayudarte a definir tipos en tu proyecto de Astro. -
gatsby-ssr.js
: Si decides utilizar SSR en Astro, deberás añadir y configurar el adaptador SSR de tu elección directamente enastro.config.mjs
.
Referencia: Convertir a Sintaxis de Astro
Sección titulada Referencia: Convertir a Sintaxis de AstroA continuación se presentan algunos ejemplos de sintaxis específica de Gatsby que deberás convertir a Astro. Consulta más diferencias entre Astro y JSX en la guía para escribir componentes de Astro.
Links de Gatsby a Astro
Sección titulada Links de Gatsby a AstroConvierte cualquier componente de Gatsby <Link to="">
, <NavLink>
u otros a etiquetas HTML <a href="">
.
Astro no utiliza ningún componente especial para los enlaces, aunque puedes construir tu propio componente <Link>
. Luego puedes importarlo y usarlo como lo harías con cualquier otro componente.
Importaciones de Gatsby a Astro
Sección titulada Importaciones de Gatsby a AstroSi es necesario, actualiza cualquier importación de archivos para que haga referencia a rutas de archivos relativas de manera exacta. Esto se puede hacer utilizando alias de importación, o escribiendo la ruta relativa completa.
Ten en cuenta que los archivos .astro
y varios otros tipos de archivo deben ser importados con su extensión de archivo completa.
Props Children de Gatsby a Astro
Sección titulada Props Children de Gatsby a AstroConvierte cualquier instancia de {children}
a un <slot />
de Astro. Astro no necesita recibir {children}
como una función de prop y automáticamente renderizará el contenido hijo en un <slot />
.
Los componentes de React que pasan múltiples conjuntos de hijos se pueden migrar a un componente Astro utilizando slots con nombre.
Puedes obtener más información sobre el uso específico de <slot />
uen Astro.
Estilos de Gatsby a Astro
Sección titulada Estilos de Gatsby a AstroEs posible que debas reemplazar cualquier biblioteca de CSS-in-JS (p. ej. styled-components) con otras opciones de CSS disponibles en Astro.
Si es necesario, convierte cualquier objeto de estilo en línea (style={{ fontWeight: "bold" }}
) a atributos de estilo en línea de HTML (style="font-weight:bold;"
). O bien, utiliza una etiqueta <style>
de Astro para estilos CSS con ámbito.
Tailwind es compatible después de instalar la integración de Tailwind. ¡No se requieren cambios en tu código de Tailwind existente!
La estilización global se logra en Gatsby mediante la importación de archivos CSS en gatsby-browser.js
. En Astro, importarás directamente archivos .css
en un componente de diseño principal para lograr estilos globales.
Ver más sobre Estilizando en Astro.
Plugin de imágenes de Gatsby a Astro
Sección titulada Plugin de imágenes de Gatsby a AstroConvierte los componentes <StaticImage />
y <GatsbyImage />
de Gatsby a los propios componentes de integración de imágenes de Astro, o a una etiqueta estándar de HTML <img>
/ JSX <img />
según corresponda en tus componentes de React.
El componente <Image />
de Astro funciona solo en archivos .astro
y .mdx
. Consulta una lista completa de sus atributos de componente y ten en cuenta que varios serán diferentes de los atributos de Gatsby.
Para seguir utilizando imágenes en archivos Markdown (.md
) utilizando la sintaxis estándar de Markdown (![]()
), es posible que necesites actualizar el enlace. El uso de la etiqueta HTML <img>
no es compatible en archivos .md
para imágenes locales, y debe ser convertido a la sintaxis de Markdown.
En componentes de React (.jsx
), utiliza la sintaxis estándar de JSX para imágenes (<img />
). Astro no optimizará estas imágenes, pero puedes instalar y utilizar paquetes de NPM para obtener más flexibilidad.
Puedes obtener más información sobre cómo usar imágenes en Astro en la Guía de Imágenes.
Gatsby GraphQL a Astro
Sección titulada Gatsby GraphQL a AstroEliminar todas las referencias a consultas de GraphQL y, en su lugar, utilizar Astro.glob()
para acceder a los datos de tus archivos locales.
O, si estás utilizando colecciones de contenido, consulta tus archivos Markdown y MDX en src/content/
utilizando getEntry()
y getCollection()
.
Estas solicitudes de datos se realizan en el frontmatter del componente Astro utilizando la variable data.
Ejemplo guiado: Convertir un diseño de Gatsby a Astro
Sección titulada Ejemplo guiado: Convertir un diseño de Gatsby a AstroEste ejemplo convierte el diseño principal del proyecto (layout.js
) del inicio de blog de Gatsby a src/layouts/Layout.astro
.
Este diseño de página muestra un encabezado cuando se visita la página de inicio y un encabezado diferente con un enlace de regreso a Home para todas las demás páginas.
-
Identifica el JSX de return().
-
Crea
Layout.astro
y agrega este valor dereturn
, convertido a la sintaxis de Astro.Toma en cuenta que:
{new Date().getFullYear()}
funciona 🎉{children}
se convierte en<slot />
🦥className
se convierte enclass
📛Gatsby
se convierte enAstro
🚀
-
Agrega una estructura de página para que tu diseño proporcione a cada página las partes necesarias de un documento HTML:
-
Agrega las importaciones, propiedades y código JavaScript necesarios
Para renderizar condicionalmente un encabezado en Astro según la ruta de la página y el título:
- Proporciona las propiedades a través de
Astro.props
. (Recuerda: en Astro, las plantillas acceden a las propiedades desde sus metadatos, no se pasan a través de una función.) - Utiliza el operador ternario para mostrar un encabezado si esta es la página de inicio y otro encabezado en caso contrario.
- Elimina las variables
{header}
y{isRootPath}
ya que ya no son necesarias. - Reemplaza las etiquetas
<Link/>
de Gatsby con etiquetas de anclaje<a>
. - Utiliza
class
en lugar declassName
. - Importa una hoja de estilo local de tu proyecto para que los nombres de clase tengan efecto.
- Proporciona las propiedades a través de
-
Actualiza
index.astro
para usar este nuevo diseño y pasarle las propiedades necesariastitle
ypathname
:Puedes obtener la ruta de la página actual utilizando
Astro.url
. -
Para probar el encabezado condicional, crea una segunda página llamada
about.astro
utilizando el mismo patrón:Sólo deberías ver un enlace a “Home” cuando visites la página About.
Recursos de la comunidad
Sección titulada Recursos de la comunidad-
Artículo de blog: Migrando de Gatsby a Astro
-
Artículo de blog: Migrar a Astro fue muy fácil.
-
Artículo de blog: Mi cambio de Gatsby a Astro.
-
Artículo de blog: Por qué me cambié a Astro desde Gatsby.
-
Artículo de blog: Migrando mi sitio web de Gatsby a Astro.
-
Artículo de blog: Otra migración: de Gatsby a Astro.
Si encontraste (¡o hiciste!) un video o publicación de blog útil sobre cómo convertir un sitio de Gatsby a Astro, edita esta página y agrégalo aquí.