Colecciones de Contenido
Agregado en:
astro@2.0.0
Las Colecciones de contenido son la mejor manera de administrar y crear contenido en cualquier proyecto de Astro. Las colecciones ayudan a organizar tus documentos, validar tu frontmatter y proporcionar una seguridad de tipo automática de TypeScript para todo tu contenido.
¿Qué son las Colecciones de Contenido?
Sección titulada ¿Qué son las Colecciones de Contenido?Una colección de contenido es cualquier directorio de nivel superior dentro del directorio reservado src/content
del proyecto, como src/content/newsletter
y src/content/authors
. Solo se permiten colecciones de contenido dentro del directorio src/content
. Este directorio no se puede utilizar para nada más.
Una entrada de colección es cualquier pieza de contenido dentro de tu directorio de colecciones de contenido. Las entradas pueden usar formatos de autoría de contenido que incluyen Markdown (.md
) y MDX (.mdx
usando la integración MDX) o como uno de los dos formatos de datos admitidos: YAML (.yaml
) y JSON (.json
). Recomendamos usar un esquema de nomenclatura consistente (minúsculas, guiones en lugar de espacios) para tus archivos para facilitar la búsqueda y organización de tu contenido, pero esto no es obligatorio. También puedes excluir las entradas de ser construidas prefijando el nombre de archivo con un guión bajo (_).
Directoriosrc/content/
Directorionewsletter/ la colección “newsletter”
- week-1.md una entrada de contenido
- week-2.md una entrada de contenido
- week-3.md una entrada de contenido
Una vez que tengas una colección, puedes comenzar a consultar tu contenido utilizando las APIs de contenido integradas de Astro.
El directorio “.astro”
Sección titulada El directorio “.astro”Astro guarda metadatos importantes para las colecciones de contenido en un directorio .astro
en tu proyecto. No es necesario que realices ninguna acción para mantener o actualizar este directorio. Se te recomienda que lo ignores por completo mientras trabajas en tu proyecto.
El directorio .astro
se actualizará automáticamente cada vez que ejecutes los comandos astro dev
, astro build
. Puedes ejecutar astro sync
en cualquier momento para actualizar el directorio .astro
manualmente.
Si estás utilizando Git para el control de versiones, te recomendamos que ignores el directorio .astro
añadiendo .astro
a tu .gitignore
. Esto le dice a Git que ignore este directorio y cualquier archivo dentro de él.
Organizando con múltiples colecciones
Sección titulada Organizando con múltiples coleccionesSi dos archivos representan diferentes tipos de contenido (por ejemplo, una publicación de blog y un perfil de autor), probablemente pertenezcan a diferentes colecciones. Esto es importante porque muchas características (validación de frontmatter, seguridad de tipo automático de TypeScript) requieren que todas las entradas de una colección compartan una estructura similar.
Si puedes trabajar con diferentes tipos de contenido, debes crear múltiples colecciones para representar cada tipo. Puedes crear tantas colecciones diferentes en tu proyecto como desees.
Directoriosrc/content/
Directorionewsletter/
- week-1.md
- week-2.md
Directorioblog/
- post-1.md
- post-2.md
Directorioauthors/
- grace-hopper.json
- alan-turing.json
Organizando con subdirectorios
Sección titulada Organizando con subdirectoriosUna colección de contenido siempre es una carpeta de nivel superior dentro del directorio src/content/
. No puedes anidar una colección dentro de otra. Sin embargo, puedes usar subdirectorios para organizar tu contenido dentro de una colección.
Por ejemplo, puedes usar la siguiente estructura de directorios para organizar las traducciones de i18n dentro de una sola colección docs
. Cuando consultes esta colección, podrás filtrar el resultado por idioma utilizando la ruta del archivo.
Directoriosrc/content/
Directoriodocs/ esta colleción usa subdirectorios para organizar por idioma
Directorioen/
- …
Directorioes/
- …
Directoriode/
- …
Definiendo Colecciones
Sección titulada Definiendo ColeccionesEl archivo src/content/config.ts
es opcional. Sin embargo, si eliges no definir tus colecciones, deshabilitarás algunas de sus mejores características como la validación del esquema del frontmatter o la generación automática de tipos de datos en TypeScript.
Para aprovechar al máximo tus colecciones de contenido, crea un archivo src/content/config.ts
en tu proyecto (también se admiten las extensiones .js
y .mjs
). Este es un archivo especial que Astro cargará y utilizará automáticamente para configurar tus colecciones de contenido.
Configurando TypeScript
Sección titulada Configurando TypeScriptSi no extiendes las configuraciones recomendadas de TypeScript strict
o strictest
de Astro en tu archivo tsconfig.json
, es posible que debas actualizar tu tsconfig.json
para habilitar strictNullChecks
.
Si usas archivos .js
o .mjs
en un proyecto de Astro, puedes habilitar IntelliSense y la comprobación de tipos en tu editor habilitando allowJs
en tu tsconfig.json
:
Definiendo un esquema de colección
Sección titulada Definiendo un esquema de colecciónLos esquemas garantizan un frontmatter o datos de entrada consistentes dentro de una colección. Un esquema garantiza que estos datos existen en una forma predecible cuando necesitas hacer referencia o consultarlos. Si algún archivo viola su esquema de colección, Astro proporcionará un error útil para informarte.
Los esquemas también potencian las generación automática de tipos de TypeScript para tu contenido en Astro. Cuando defines un esquema para tu colección, Astro generará y aplicará automáticamente una interfaz de TypeScript. El resultado es un soporte completo de TypeScript cuando consultas tu colección, incluyendo el autocompletado de propiedades y la comprobación de tipos.
Para definir tu primera colección, crea un archivo src/content/config.ts
si no existe (las extensiones .js
y .mjs
también son compatibles). Este archivo debe:
- Importar las utilidades adecuadas de
astro:content
. - Definir cada colección que deseas validar. Esto incluye un
type
(introducido en Astro v2.5.0) que especifica si la colección contiene formatos de autoría de contenido como Markdown (type: 'content'
) o formatos de datos como JSON o YAML (type: 'data'
). También incluye unschema
que define la forma de tu frontmatter o datos de entrada. - Exportar un único objeto
collections
para registrar tus colecciones.
Definiendo múltiples colecciones
Sección titulada Definiendo múltiples coleccionesPuedes usar defineCollection()
tantas veces como desees para crear múltiples esquemas. Todas las colecciones deben ser exportadas desde dentro del único objeto collections
.
A medida que tu proyecto crece, también eres libre de reorganizar tu base de código y mover la lógica fuera del archivo src/content/config.ts
. Definir tus esquemas por separado puede ser útil para reutilizar esquemas en múltiples colecciones y compartir esquemas con otras partes de tu proyecto.
Usando esquemas de colección de terceros
Sección titulada Usando esquemas de colección de tercerosPuedes importar esquemas de colección desde cualquier lugar, incluyendo paquetes npm externos. Esto puede ser útil cuando trabajas con temas y bibliotecas que proporcionan sus propios esquemas de colección para que los uses.
Definiendo tipos de datos con Zod
Sección titulada Definiendo tipos de datos con ZodAstro usa Zod para potenciar sus esquemas de contenido. Con Zod, Astro puede validar el frontmatter de cada archivo dentro de una colección y proporcionar tipos automáticos de TypeScript cuando consultas el contenido desde dentro de tu proyecto.
Para usar Zod en Astro, importa la utilidad z
de "astro:content"
. Esta es una re-exportación de la biblioteca Zod, y admite todas las funciones de Zod. Consulta el README de Zod para obtener documentación completa sobre cómo funciona Zod y qué funciones están disponibles.
Definiendo referencias de colección
Sección titulada Definiendo referencias de colecciónLas entradas de una colección pueden “referenciar” otras entradas relacionadas.
Con la función reference()
de la API de Colecciones, puedes definir una propiedad en un esquema de colección como una entrada de otra colección. Por ejemplo, puedes requerir que cada entrada space-shuttle
incluya una propiedad pilot
que utilice el propio esquema de la colección pilot
para la comprobación de tipos, el autocompletado y la validación.
Un ejemplo común es una publicación de blog que hace referencia a perfiles de autor reutilizables almacenados como JSON, o a URL de publicaciones relacionadas almacenadas en la misma colección:
Este ejemplo de publicación de blog especifica los slug
de las publicaciones relacionadas y el id
del autor de la publicación:
Definiendo slugs personalizados
Sección titulada Definiendo slugs personalizadosCuando usas type: 'content'
, cada entrada de contenido genera una propiedad slug
compatible con URL a partir de su id
de archivo. El slug se utiliza para consultar la entrada directamente desde tu colección. También es útil cuando creas nuevas páginas y URL a partir de tu contenido.
Puedes anular el slug generado de una entrada añadiendo tu propia propiedad slug
al frontmatter del archivo. Esto es similar a la función “permalink” de otros frameworks web. "slug"
es un nombre de propiedad especial y reservado que no está permitido en tu schema
de colección personalizado y no aparecerá en la propiedad data
de tu entrada.
Consultando Colecciones
Sección titulada Consultando ColeccionesAstro proporciona dos funciones para consultar una colección y devolver una (o más) entradas de contenido: getCollection()
y getEntry()
.
Ambas funciones devuelven entradas de contenido tal como se definen en el tipo CollectionEntry
.
Accediendo a los datos referenciados
Sección titulada Accediendo a los datos referenciadosCualquier referencia definida en tu esquema debe consultarse por separado después de consultar por primera vez la entrada de tu colección. Puedes usar la función getEntry()
de nuevo, o getEntries()
, para recuperar la entrada referenciada del objeto data
devuelto.
Filtrando consultas de colección
Sección titulada Filtrando consultas de coleccióngetCollection()
toma un callback opcional “filter” que te permite filtrar tu consulta en función de las propiedades id
o data
(frontmatter) de una entrada. Para las colecciones de type: 'content'
, también puedes filtrar en función de slug
.
La propiedad slug
es específica de las colecciones de contenido y no estará disponible al filtrar colecciones de JSON o YAML.
Puedes usar esto para filtrar por cualquier criterio de contenido que desees. Por ejemplo, puedes filtrar por propiedades como draft
para evitar que se publiquen publicaciones de blog en borrador en tu blog:
También puedes crear páginas en borrador que estarán disponibles cuando ejecutes el servidor de desarrollo, pero que no se construirán en producción:
Para filtrar argumentos también admite el filtrado por directorios anidados dentro de una colección. Dado que el id
incluye la ruta anidada completa, puedes filtrar por el inicio de cada id
para devolver solo los elementos de un directorio anidado específico:
Usando contenido en plantillas de Astro
Sección titulada Usando contenido en plantillas de AstroUna vez que hayas consultado tus entradas de colección, puedes acceder a cada entrada directamente dentro de la plantilla de tu componente de Astro. Esto te permite renderizar HTML para cosas como enlaces a tu contenido (usando el slug
de contenido) o información sobre tu contenido (usando la propiedad data
).
Para obtener información sobre cómo renderizar tu contenido a HTML, consulta Renderizando contenido a HTML a continuación.
Pasando contenido como props
Sección titulada Pasando contenido como propsUn componente también puede pasar un contenido completo como una prop.
Si haces esto, puedes usar la utilidad CollectionEntry
para tipar correctamente las props de tu componente usando TypeScript. Esta utilidad toma un argumento de tipo string que coincide con el nombre del esquema de tu colección y heredará todas las propiedades de ese esquema de colección.
Renderizando contenido a HTML
Sección titulada Renderizando contenido a HTMLUna vez consultado, puedes renderizar las entradas de Markdown y MDX a HTML usando la propiedad de función render()
de la entrada. Llamar a esta función te da acceso al contenido y metadatos renderizados, incluyendo tanto un componente <Content />
como una lista de todos los encabezados renderizados.
Generando Rutas desde el Contenido
Sección titulada Generando Rutas desde el ContenidoLas Colecciones de contenido se almacenan fuera del directorio src/pages/
. Esto significa que no se generan rutas para los elementos de tu colección de forma predeterminada. Deberás crear manualmente una nueva ruta dinámica para generar páginas HTML a partir de las entradas de tu colección. Tu ruta dinámica asignará el parámetro de solicitud entrante (por ejemplo, Astro.params.slug
en src/pages/blog/[...slug].astro
) para recuperar la entrada correcta dentro de una colección.
El método exacto para generar rutas dependerá del modo de salida de tu compilación output
: ‘static’ (el valor predeterminado) o ‘server’ (para SSR).
Construyendo para salida estática (predeterminado)
Sección titulada Construyendo para salida estática (predeterminado)Si estás construyendo un sitio web estático (el comportamiento predeterminado de Astro), debes usar la función getStaticPaths()
para crear múltiples páginas a partir de un solo componente src/pages/
durante tu compilación.
Llama a getCollection()
dentro de getStaticPaths()
para consultar tu contenido. Luego, crea tus nuevas rutas URL utilizando la propiedad slug
de cada entrada de contenido.
Esto generará una nueva página para cada entrada en la colección blog
. Por ejemplo, una entrada en src/content/blog/hello-world.md
tendrá un slug de hello-world
, y por lo tanto su URL final será /posts/hello-world/
.
Si tus slugs personalizados contienen el carácter /
para producir URLs con múltiples segmentos de ruta, debes usar un parámetro rest ([...slug]
) en el nombre de archivo .astro
para esta página de enrutamiento dinámico.
Construyendo para salida del servidor (SSR)
Sección titulada Construyendo para salida del servidor (SSR)Si estás construyendo un sitio web dinámico (usando el soporte SSR de Astro), no se espera que generes ninguna ruta de antemano durante la compilación. En su lugar, tu página debe examinar la solicitud (usando Astro.request
o Astro.params
) para encontrar el slug
bajo demanda, y luego recuperarlo usando getEntry()
.
Migrando desde el Enrutamiento Basado en Archivos
Sección titulada Migrando desde el Enrutamiento Basado en ArchivosSi tienes un proyecto de Astro existente como un blog, que usa archivos Markdown o MDX en subcarpetas dentro de src/pages/
, considera migrar los archivos de contenido o datos relacionados a las colecciones de contenido.
Consulta cómo convertir un ejemplo básico de blog de src/pages/posts/
a src/content/posts
en nuestro tutorial paso a paso que utiliza la base de código del proyecto terminado del tutorial Crear un Blog.
Habilitando el Caché de Construcción
Sección titulada Habilitando el Caché de Construcción
Agregado en:
astro@3.5.0
Experimental
Si estás trabajando con colecciones grandes, es posible que desees habilitar las compilaciones en caché con la bandera experimental.contentCollectionCache
. Esta característica experimental optimiza el proceso de compilación de Astro, permitiendo que las colecciones no modificadas se almacenen y reutilicen entre compilaciones.
En muchos casos, esto puede conducir a mejoras significativas en el rendimiento de la compilación.
Mientras esta característica se estabiliza, es posible que te encuentres con problemas con la caché almacenada. Siempre puedes restablecer tu caché de compilación ejecutando el siguiente comando:
Modificando el Frontmatter con Remark
Sección titulada Modificando el Frontmatter con RemarkNo es recomendado. Los plugins de remark y rehype acceden al frontmatter raw del documento Markdown o MDX. Esto significa que el frontmatter remarkPluginFrontmatter
se maneja por separado de tu schema
de tipo seguro, y no reflejará ningún cambio o valor predeterminado aplicado a través de Astro. ¡Úsalo bajo tu propio riesgo!
Astro admite los plugins remark o rehype que modifican tu frontmatter directamente. Puedes acceder a este frontmatter modificado dentro de una entrada de contenido usando la propiedad remarkPluginFrontmatter
devuelta de render()
:
Los pipelines de remark y rehype solo se ejecutan cuando se renderiza tu contenido, lo que explica por qué remarkPluginFrontmatter
solo está disponible después de llamar a render()
en tu entrada de contenido. En contraste, getCollection()
y getEntry()
no pueden devolver estos valores directamente porque no renderizan tu contenido.
Trabajando con fechas en el frontmatter
Sección titulada Trabajando con fechas en el frontmatterMuchos formatos de fecha son admitidos en las colecciones de contenido, pero el esquema de tu colección debe coincidir con el formato utilizado en el frontmatter YAML de tu Markdown o MDX.
YAML usa el estándar ISO-8601 para expresar fechas. Utiliza el formato yyyy-mm-dd
(por ejemplo, 2021-07-28
) junto con un tipo de esquema de z.date()
:
El formato de fecha se especificará en UTC si no se proporciona una zona horaria. Si necesitas especificar una zona horaria, puedes usar el formato ISO 8601.
Para renderizar solo YYYY-MM-DD
de la marca de tiempo UTC completa, utiliza el método slice
de JavaScript para eliminar la marca de tiempo:
Para ver un ejemplo usando toLocaleDateString
para formatear el día, mes y año, consulta el componente <FormattedDate />
en la plantilla oficial del blog de Astro.