Pular para o conteúdo

Referência da API

A global Astro está disponível em todos os contextos em arquivos .astro. Ela tem as seguintes funções:

Astro.glob() é uma forma de carregar vários arquivos locais em seu site estático.

src/components/meu-componente.astro
---
const postagens = await Astro.glob('../pages/postagens/*.md'); // retorna um array de postagens que estão em ./src/pages/postagens/*.md
---
<div>
{postagens.slice(0, 3).map((postagem) => (
<article>
<h2>{postagem.frontmatter.titulo}</h2>
<p>{postagem.frontmatter.descricao}</p>
<a href={postagem.url}>Leia mais</a>
</article>
))}
</div>

.glob() recebe apenas um parâmetro: uma URL relativa dos arquivos locais que você gostaria de importar. Ela é assíncrona e retorna um array das exportações dos arquivos correspondentes.

.glob() não pode receber variáveis ou strings que são interpoladas já que não são estaticamente analisáveis. (Veja o guia de solução de problemas para uma solução alternativa.) Isso acontece pois Astro.glob() é feito em cima do import.meta.glob() do Vite.

Arquivos Markdown tem a seguinte interface:

export interface MarkdownInstance<T extends Record<string, any>> {
/* Quaisquer dados especificados no frontmatter YAML deste arquivo */
frontmatter: T;
/* O caminho do arquivo deste arquivo */
file: string;
/* O caminho renderizado deste arquivo */
url: string | undefined;
/* Componente Astro que renderiza os conteúdos deste arquivo */
Content: AstroComponent;
/* Função que retorna um array de elementos h1...h6 deste arquivo */
getHeadings(): Promise<{ depth: number; slug: string; text: string }[]>;
}

Você pode opcionalmente oferecer um tipo para a variável frontmatter utilizando um generic do TypeScript.

---
interface Frontmatter {
titulo: string;
descricao?: string;
}
const postagens = await Astro.glob<Frontmatter>('../pages/postagens/*.md');
---
<ul>
{postagens.map(postagem => <li>{postagem.frontmatter.titulo}</li>)}
</ul>

Arquivos Astro tem a seguinte interface:

export interface AstroInstance {
/* O caminho de arquivo deste arquivo */
file: string;
/* A URL para este arquivo (se ele estiver no diretório pages) */
url: string | undefined;
default: AstroComponent;
}

Outros arquivos podem ter várias diferentes interfaces, mas Astro.glob() aceita um generic do TypeScript se você souber exatamente o que o tipo de um arquivo desconhecido contém.

---
interface DadosCustomizadosArquivo {
default: Record<string, any>;
}
const dados = await Astro.glob<DadosCustomizadosArquivo>('../dados/**/*.js');
---

Astro.props é um objeto contendo quaisquer valores que foram passados como atributos do componente. Componentes de Layout para arquivos .md e .mdx recebem valores frontmatter como props.

src/components/Titulo.astro
---
const { titulo, data } = Astro.props;
---
<div>
<h1>{titulo}</h1>
<p>{data}</p>
</div>
src/pages/index.astro
---
import Titulo from '../components/Titulo.astro';
---
<Titulo titulo="Minha Primeira Postagem" data="09 Ago 2022" />

📚 Aprenda mais sobre como Layouts Markdown e MDX lidam com props.

📚 Aprenda mais sobre como adicionar definições de tipo do TypeScript para suas props.

Astro.params é um objeto que contém os valores de segmentos dinâmicos de rota que correspondem a essa requisição.

Em builds estáticas, ele será o params retornado por getStaticPaths() usado para pré-renderizar rotas dinâmicas.

Em builds SSR, ele pode ser qualquer valor correspondente aos segmentos do caminho no padrão da rota dinâmica.

src/pages/postagens/[id].astro
---
export function getStaticPaths() {
return [
{ params: { id: '1' } },
{ params: { id: '2' } },
{ params: { id: '3' } }
];
}
const { id } = Astro.params;
---
<h1>{id}</h1>

Veja também: params

Astro.request é um objeto Request padrão. Ele pode ser utilizado para obter a url, headers, method e até mesmo o body de uma requisição.

<p>Recebido uma requisição {Astro.request.method} para "{Astro.request.url}".</p>
<p>Headers da requisição recebidos: <code>{JSON.stringify(Object.fromEntries(Astro.request.headers))}</code>

Veja também: Astro.url

Astro.response é um objeto ResponseInit padrão. Ele tem a seguinte estrutura.

  • status: O código numérico do status da resposta, e.x., 200.
  • statusText: A mensagem de status associada com o código de status, e.x., 'OK'
  • headers: Uma instância de Headers que você pode usar para definir os cabeçalhos HTTP da resposta.

Astro.response é usado para definir o status, statusText e headers para a resposta de uma página.

---
if(condicao) {
Astro.response.status = 404;
Astro.response.statusText = 'Não encontrado';
}
---

Ou para definir um header:

---
Astro.response.headers.set('Set-Cookie', 'a=b; Path=/;');
---
Adicionado em: astro@1.4.0

Astro.cookies contém utilitários para a leitura e manipulação de cookies no modo de renderização no lado do servidor.

NomeTipoDescrição
get(key: string) => AstroCookiePega o cookie como um objeto AstroCookie, que contém value e funções utilitários para converter o cookie em tipos que não sejam string.
has(key: string) => booleanSe o cookie existe. Se o cookie foi definido com Astro.cookies.set(), ele irá retornar true, e caso contrário, ele irá checar cookies em Astro.request.
set(key: string, value: string | number | boolean | object, options?: CookieOptions) => voidDefine o cookie key para o valor dado. Ele tentará converter o valor do cookie para uma string. Opções providenciam formas de definir funcionalidades de cookies, como maxAge ou httpOnly.
delete(key: string, options?: CookieDeleteOptions) => voidMarca o cookie como deletado. Assim que o cookie é deletado, Astro.cookies.has() irá retornar false e Astro.cookies.get() irá retornar um AstroCookie com o value igual a undefined. Opções permitem definir o domain e o path do cookie a ser deletado.
headers() => Iterator<string>Pega os valores de header para Set-Cookie que serão enviados com a resposta.

Pegar um cookie com Astro.cookies.get() retorna um tipo AstroCookie. Ele tem a seguinte estrutura.

NomeTipoDescrição
valuestring| undefinedO valor bruto em string do cookie.
json() => Record<string, any>Faz parse do valor do cookie com JSON.parse(), retornando um objeto. Joga um erro se o valor do cookie não é JSON válido.
number() => numberFaz parse do valor do cookie como um Number. Retorna NaN se não for um número válido.
boolean() => booleanConverte o valor do cookie para uma boolean.

Astro.redirect() permite você redirecionar para outra página. Uma página (e não um componente filho) precisa retornar (com return) o resultado de Astro.redirect() para o redirecionamento acontecer.

src/pages/conta.astro
---
import { estaLogado } from '../utils';
const cookie = Astro.request.headers.get('cookie');
// Se o usuário não está logado, redireciona ele para a página de login
if (!estaLogado(cookie)) {
return Astro.redirect('/login');
}
---

A URL canônica da página atual.

Adicionado em: astro@1.0.0-rc

Um objeto URL construído a partir do valor da string URL atual do Astro.request.url. Útil para interagir com propriedades individuais da URL da requisição, como o nome do caminho e origem.

Equivalente a fazer new URL(Astro.request.url).

<h1>A URL atual é: {Astro.url}</h1>
<h1>O nome do caminho da URL atual é: {Astro.url.pathname}</h1>
<h1>A origem da URL atual é: {Astro.url.origin}</h1>

Você também pode usar Astro.url para criar novas URLs a passando como um argumento em new URL().

src/pages/index.astro
---
// Exemplo: Construa uma URL canônica usando seu domínio em produção
const URLCanonica = new URL(Astro.url.pathname, Astro.site);
// Exemplo: Construa uma URL para tags meta SEO usando seu domínio atual
const URLImagemSocial = new URL('/imagens/preview.png', Astro.url);
---
<link rel="canonical" href={URLCanonica} />
<meta property="og:image" content={URLImagemSocial} />
Adicionado em: astro@1.0.0-rc

Especifica o endereço de IP da requisição. Esta propriedade é apenas disponível ao fazer build para SSR (renderização no lado do servidor) e não deve ser usado em sites estáticos.

---
const ip = Astro.clientAddress;
---
<div>Your IP address is: <span class="address">{ ip }</span></div>

Astro.site retorna a URL feita a partir do site na sua configuração do Astro. Se site na sua configuração do Astro não estiver definido, Astro.site não será definido.

Adicionado em: astro@1.0.0

Astro.generator é uma forma conveniente de adicionar uma tag <meta name="generator"> na sua versão atual do Astro. Ela segue o formato "Astro v1.x.x".

<html>
<head>
<meta name="generator" content={Astro.generator} />
</head>
<body>
<footer>
<p>Construído com <a href="https://astro.build">{Astro.generator}</a></p>
</footer>
</body>
</html>

Astro.slots contém funções utilitárias para modificar os filhos em slots de um componente Astro.

Tipo: (slotName: string) => boolean

Você pode checar se existe conteúdo para um nome de slot específico com Astro.slots.has(). Isso pode ser útil quando você quer envolver conteúdos de slots, mas apenas quer renderizar os elementos que os envolvem quando o slot está sendo utilizado.

src/pages/index.astro
---
---
<slot />
{Astro.slots.has('mais') && (
<aside>
<h2>Mais</h2>
<slot name="mais" />
</aside>
)}

Tipo: (slotName: string, args?: any[]) => Promise<string>

Você pode renderizar de forma assíncrona os conteúdos de um slot para uma string de HTML utilizando Astro.slots.render().

---
const html = await Astro.slots.render('default');
---
<Fragment set:html={html} />

Astro.slots.render() opcionalmente aceita um segundo argumento: um array de parâmetros que serão passados para quaisquer funções filho. Isso pode ser útil para componentes utilitários customizados.

Por exemplo, esse componente <Grito /> converte sua prop mensagem para letras maiúsculas e o passa como o slot padrão:

src/components/Grito.astro
---
const mensagem = Astro.props.mensagem.toUpperCase();
let html = '';
if (Astro.slots.has('default')) {
html = await Astro.slots.render('default', [mensagem]);
}
---
<Fragment set:html={html} />

Uma função de callback passada como filho de <Grito /> receberá o parâmetro mensagem em letras maiúsculas:

src/pages/index.astro
---
import Grito from "../components/Grito.astro";
---
<Grito mensagem="slots!">
{(mensagem) => <div>{mensagem}</div>}
</Grito>
<!-- renderizado como <div>SLOTS!</div> -->

Astro.self permite que componentes Astro sejam recursivamente invocados. Este comportamento te permite renderizar um componente Astro em si mesmo utilizando <Astro.self> no template do componente. Isto pode ser útil para iterar sobre grandes coleções e estruturas de dados aninhadas.

ListaAninhada.astro
---
const { itens } = Astro.props;
---
<ul class="lista-aninhada">
{itens.map((item) => (
<li>
<!-- Se houver uma estrutura de dados aninhada nós renderizamos `<Astro.self>` -->
<!-- e podemos passar props através de uma invocação recursiva -->
{Array.isArray(item) ? (
<Astro.self items={item} />
) : (
item
)}
</li>
))}
</ul>

Este componente pode ser utilizado assim:

---
import ListaAninhada from './ListaAninhada.astro';
---
<ListaAninhada itens={['A', ['B', 'C'], 'D']} />

E renderizaria HTML assim:

<ul class="lista-aninhada">
<li>A</li>
<li>
<ul class="lista-aninhada">
<li>B</li>
<li>C</li>
</ul>
</li>
<li>D</li>
</ul>

Astro.locals é um objeto contendo quaisquer valores do objeto context.locals de um middleware. Use isso para acessar dados retornados por um middleware em seus arquivos .astro.

src/pages/Pedidos.astro
---
const titulo = Astro.locals.tituloBoasVindas();
const pedidos = Array.from(Astro.locals.pedidos.entries());
---
<h1>{titulo}</h1>
<ul>
{pedidos.map(pedido => {
return <li>{/* faz alguma coisa com cada pedido */}</li>
})}
</ul>

Astro.perferedLocale é um valor computado que representa o idioma de preferência do usuário.

Ele é computado checando as configurações de idioma do seu array i18n.locales e os idiomas suportados pelo navegado do usuário através do cabeçalho Accept-Language. Esse valor é undefined se não houver uma correspondência.

Essa propriedade só está disponível ao fazer o build em modo SSR (renderização do lado do servidor) e não deve ser utilizada em sites estáticos.

Astro.preferedLocaleList representa a lista de todos o slocales que são tanto requisitados pelo navegador quanto suportados pelo seu website. Isso produz uma lista de todas as linguagens compatíveis entre o seu site e seu visitante.

Se nenhuma das linguagens requesitadas pelo navegador forem encontradas na sua lista de idiomas, então o valor é []: você não suporta nenhum dos idiomas de preferência do seu visitante.

Se o navegador não especificar nenhuma linguagem de preferência, então esse valor será igual ao i18n.locales: todas os seus idiomas suportados serão considerados igualmente aceitáveis pelo visitante sem nenhuma preferênca.

Essa propriedade só está disponível ao fazer o build em modo SSR (renderização do lado do servidor) e não deve ser utilizada em sites estáticos.

O idioma computado a partir da URL atual, utilizando a sintaxe definida em sua configuração locales. Se a URL não incluir um prefixo /[locale]/, então o valor será o padrão definido em i18n.defaultLocale.

Funções de Endpoint recebem um objeto de contexto como primeiro parâmetro. Ele copia muitas das propriedades da global Astro.

endpoint.json.ts
import type { APIContext } from 'astro';
export function GET(context: APIContext) {
// ...
}

context.params é um objeto que contém os valores de segmentos dinâmicos de rota que correspondem a essa requisição.

Em builds estáticas, ele será o params retornado por getStaticPaths() usado para pré-renderizar rotas dinâmicas.

Em builds SSR, ele pode ser qualquer valor correspondente aos segmentos do caminho no padrão da rota dinâmica.

src/pages/postagens/[id].json.ts
import type { APIContext } from 'astro';
export function getStaticPaths() {
return [
{ params: { id: '1' } },
{ params: { id: '2' } },
{ params: { id: '3' } }
];
}
export function GET({ params }: APIContext) {
return new Response(
JSON.stringify({ id: params.id }),
);
}

Veja também: params

context.props é um objeto que contém quaisquer props passadas de getStaticPaths(). Por conta de getStaticPaths() não ser usado ao fazer build para SSR (renderização no lado do servidor), context.props está disponível apenas em builds estáticas.

src/pages/postagens/[id].json.ts
import type { APIContext } from 'astro';
export function getStaticPaths() {
return [
{ params: { id: '1' }, props: { autor: 'Blu' } },
{ params: { id: '2' }, props: { autor: 'Erika' } },
{ params: { id: '3' }, props: { autor: 'Matthew' } }
];
}
export function GET({ props }: APIContext) {
return new Response(
JSON.stringify({ autor: props.autor }),
);
}

Veja também: Passagem de dados com props

Um objeto Request padrão. Ele pode ser utilizado para conseguir a url, headers, method e até mesmo body da requisição.

import type { APIContext } from 'astro';
export function GET({ request }: APIContext) {
return {
body: `Olá ${request.url}`
}
}

Veja também: Astro.request

context.cookies contém utilitários para a leitura e manipulação de cookies.

Veja também: Astro.cookies

Um objeto URL construído do valor string context.request.url da URL atual.

Veja também: Astro.url

Especifica o endereço de IP da requisição. Essa propriedade só está disponível ao fazer build para SSR (renderização no lado do servidor) e não deve ser utilizada para sites estáticos.

import type { APIContext } from 'astro';
export function GET({ clientAddress }: APIContext) {
return new Response(`Seu endereço de IP é: ${clientAddress}`);
}

Veja também: Astro.clientAddress

context.site retorna uma URL feita do site na sua configuração do Astro. Se for undefined, ela irá retornar uma URL gerada a partir de localhost.

Veja também: Astro.site

context.generator é uma forma conveniente de indicar a versão do Astro em que seu projeto está. Ela segue o formato "Astro v1.x.x".

src/pages/informacao-site.json.ts
import type { APIContext } from 'astro';
export function GET({ generator, site }: APIContext) {
const body = JSON.stringify({ generator, site });
return new Response(body);
}

Veja também: Astro.generator

context.redirect() retorna um objeto Response que te permite redirecionar para outra página. Essa função está disponível apenas ao fazer build para SSR (renderização no lado do servidor) e não deve ser utilizada para sites estáticos.

import type { APIContext } from 'astro';
export function GET({ redirect }: APIContext) {
return redirect('/login', 302);
}

Veja também: Astro.redirect

context.locals é um objeto usado para armazenar e acessar informações arbitrárias durante o ciclo de vida de uma requisição.

Funções de middleware podem ler e escrever valores do context.locals:

src/middleware.ts
import type { MiddlewareResponseHandler } from 'astro';
export const onRequest: MiddlewareResponseHandler = ({ locals }, next) => {
if (!locals.titulo) {
locals.titulo = "Título Padrão";
}
return next();
}

Endpoints de API so podem ler informações do context.locals:

src/pages/hello.ts
import type { APIContext } from 'astro';
export function GET({ locals }: APIContext) {
return new Response(locals.titulo); // "Título Padrão"
}

Veja também: Astro.locals

Se uma página utiliza parâmetros dinâmicos em seu nome de arquivo, tal componente precisará exportar uma função getStaticPaths().

Esta função é necessária pois Astro é um gerador de sites estáticos. Isso significa que o seu site inteiro é construído previamente. Se Astro não sabe como gerar uma página em tempo de build, seus usuários não o irão ver quando visitarem o seu site.

---
export async function getStaticPaths() {
return [
{ params: { /* obrigatório */ }, props: { /* opcional */ } },
{ params: { ... } },
{ params: { ... } },
// ...
];
}
---
<!-- O seu template HTML aqui. -->

A função getStaticPaths() deve retornar um array de objetos para determinar quais caminhos serão pré-renderizados pelo Astro.

Ela também pode ser utilizada para endpoints de arquivos estáticos para roteamento dinâmico.

A chave params de todos os objetos retornados diz ao Astro quais rotas construir. Os parâmetros retornados devem ser mapeados de volta para os parâmetros dinâmicos e rest definidos no caminho de arquivo do seu componente.

params são codificados na URL, então apenas strings são suportadas como valores. O valor para cada objeto params deve corresponder aos parâmetros utilizados no nome da página.

Por exemplo, suponha que você tem uma página em src/pages/postagens/[id].astro. Se você exportar getStaticPaths dessa página e retornar os seguintes caminhos:

---
export async function getStaticPaths() {
return [
{ params: { id: '1' } },
{ params: { id: '2' } },
{ params: { id: '3' } }
];
}
const { id } = Astro.params;
---
<h1>{id}</h1>

Então Astro irá estaticamente gerar postagens/1,, postagens/2, e postagens/3 em tempo de build.

Para passar dados adicionais para cada página gerada, você também pode definir um valor a props para cada objeto de caminho retornado. Diferente de params, props não são codificadas na URL, então não estão limitadas a apenas strings.

Por exemplo, supomos que você gera páginas baseando-se em dados buscados a partir de uma API remota. Você pode passar o objeto inteiro dos dados para o componente da página dentro de getStaticPaths:

---
export async function getStaticPaths() {
const dados = await fetch('...').then(resposta => resposta.json());
return dados.map((postagem) => {
return {
params: { id: postagem.id },
props: { postagem },
};
});
}
const { id } = Astro.params;
const { postagem } = Astro.props;
---
<h1>{id}: {postagem.nome}</h1>

Você também pode passar um array normal, que pode ser útil quando for gerar ou esboçar uma lista conhecida de rotas.

---
export async function getStaticPaths() {
const postagens = [
{id: '1', categoria: "astro", titulo: "Referência da API"},
{id: '2', categoria: "react", titulo: "Criando um contador com React!"}
];
return postagens.map((postagem) => {
return {
params: { id: postagem.id },
props: { postagem }
};
});
}
const {id} = Astro.params;
const {postagem} = Astro.props;
---
<body>
<h1>{id}: {postagem.titulo}</h1>
<h2>Categoria: {postagem.categoria}</h2>
</body>

Então Astro irá estaticamente gerar postagens/1 e postagens/2 em tempo de build utilizando o componente da página em pages/postagens/[id].astro. A página pode referenciar esses dados utilizando Astro.props:

Paginação é um caso de uso comum para websites que Astro nativamente suporta através da função paginate(). paginate() irá automaticamente gerar o array para retornar de getStaticPaths() que cria uma URL para cada página da coleção paginada. O número da página será passado como um parâmetro, e os dados da página serão passados como a prop page.

export async function getStaticPaths({ paginate }) {
// Carregue seus dados com fetch(), Astro.glob(), etc.
const resposta = await fetch(`https://pokeapi.co/api/v2/pokemon?limit=150`);
const resultado = await resposta.json();
const todosPokemons = resultado.results;
// Retorna a coleção paginada de caminhos para todas as postagens
return paginate(todosPokemons, { pageSize: 10 });/*-
}
// Se configurado propriamente, a prop page agora tem tudo
// o que você precisa para renderizar uma única página (veja a próxima seção)
const { page } = Astro.props;

paginate() assume um nome de arquivo [page].astro ou [...page].astro. O parâmetro page se torna o número da página em sua URL:

  • /postagens/[page].astro geraria as URLs /postagens/1, /postagens/2, /postagens/3, etc.
  • /postagens/[...page].astro geraria as URLs /postagens, /postagens/2, /postagens/3, etc.

paginate() recebe os seguintes argumentos:

  • pageSize - O número de itens exibidos por página
  • params - Envie parâmetros adicionais para criar rotas dinâmicas
  • props - Envie props adicionais para serem disponibilizadas em cada página

A paginação irá passar a prop page para cada página renderizada que representa uma única página de dados na coleção paginada. Isso inclui dados que você paginou (page.data) assim como metadados para a página (page.url, page.start, page.end, page.total, etc). Estes metadados são úteis para coisas como um botão de “Próxima Página” ou uma mensagem “Mostrando 1-10 de 100”.

NomeTipoDescrição
page.dataArrayArray dos dados retornados de data() para a página atual.
page.startnumberÍndice do primeiro item na página atual, começando em 0 (e.x. se pageSize: 25, isso seria 0 na página 1, 25 na página 2, etc.).
page.endnumberÍndice do último item na página atual.
page.sizenumberQuantos itens há por página.
page.totalnumberO número total de itens em todas as páginas.
page.currentPagenumberO número da página atual, começando por 1.
page.lastPagenumberO número total de páginas.
page.url.currentstringURL da página atual (útil para URLs canônicas)
page.url.prevstring | undefinedURL da página anterior (será undefined se estiver na página 1).
page.url.nextstring | undefinedURL da próxima página (será undefined se não houverem mais páginas).

Todos os módulos ESM incluem a propriedade import.meta. Astro adiciona import.meta.env através do Vite.

import.meta.env.SSR pode ser utilizado para saber quando se está sendo renderizado no servidor. As vezes você pode querer uma lógica diferente, por exemplo, para um componente que deve ser apenas renderizado no cliente:

export default function () {
return import.meta.env.SSR ? <div class="spinner"></div> : <ComponenteComplexo />;
}

A função getImage() tem a intenção de gerar imagens para serem usadas em lugares não diretamente no HTML, por exemplo em uma Rota de API. Ela também permite que você crie seu próprio componente <Image /> customizado.

getImage() recebe um objeto de opções com as mesmas propriedades do componente “Image” (exceto alt).

---
import { getImage } from "astro:assets";
import meuPlanoDeFundo from "../planoDeFundo.png";
const planoDeFundoOtimizado = await getImage({src: meuPlanoDeFundo, format: 'avif'});
---
<div style={`background-image: url(${planoDeFundoOtimizado.src});`}></div>

Ela retorna um objeto com as seguintes propriedades:

{
options: {...}, // Parâmetros originais passados
src: "https://...", // Caminho para a imagem gerada
attributes: {...}, // Atributos HTML adicionais necessários para renderizar a imagem (width, height, style, etc...)
}

Coleções de Conteúdo (astro:content)

Seção intitulada Coleções de Conteúdo (astro:content)

Adicionado em: astro@2.0.0

Coleções de conteúdo oferecem APIs para configurar e buscar seus documentos Markdown ou MDX em src/content/. Para funcionalidades e exemplos de uso, veja nosso guia de coleções de conteúdo.

defineCollection() é um utilitário para configurar uma coleção em um arquivo src/content/config.*.

src/content/config.ts
import { z, defineCollection } from 'astro:content';
const blog = defineCollection({
type: 'content',
schema: z.object({
titulo: z.string(),
permalink: z.string().optional(),
}),
});
// Exponha sua coleção definida ao Astro
// com a exportação `collections`
export const collections = { blog };

Essa função aceita as seguintes propriedades:

Adicionado em: astro@2.5

Tipo: 'content' | 'data' Padrão: 'content'

O type é uma string que define o tipo das entidades armazenadas dentro de uma coleção:

  • 'content' - para formatos de autoria de conteúdo como Markdown (.md), MDX (.mdx) ou Markdoc (.mdoc)
  • 'data' - para formatos exclusivamente de dados como JSON (.json) ou YAML (.yaml)

Tipo: TSchema extends ZodType

schema é um objeto Zod opcional para configurar o tipo e formato do frontmatter do documento para uma coleção. Cada valor do objeto deve utilizar um validador do Zod.

Veja o guia de Coleções de Conteúdo para exemplos de uso.

Tipo: (collection: string) => ZodEffects<ZodString, { collection, id: string } | { collection, slug: string }>

A função reference() é usada na configuração de conteúdo para definir uma relação, ou “referência”, de uma coleção com a outra. Ela aceita um nome de coleção e valida o(s) identificador(es) de entrada especificados no frontmatter do seu conteúdo ou arquivo de dados.

Esse exemplo define referências de um autor de blog para a coleção autores e um array de postagens relacionadas na mesma coleção blog:

import { defineCollection, reference, z } from 'astro:content';
const blog = defineCollection({
type: 'content',
schema: z.object({
// Referencia um único autor da coleção `autores` pelo `id`
autor: reference('autores'),
// Referencia um array de postagens relacionadas da coleção `blog` pelo `slug`
postagensRelacionadas: z.array(reference('blog')),
})
});
const autores = defineCollection({
type: 'data',
schema: z.object({ /* ... */ })
});
export const collections = { blog, autores };

Veja o guia Coleções de Conteúdo para um exemplo de uso.

Tipo: (collection: string, filter?: (entry: CollectionEntry<collection>) => boolean) => CollectionEntry<collection>[]

getCollection() é uma função que devolve a lista de entradas de coleções de conteúdo por nome de coleção.

Ela retorna todos os itens em uma coleção por padrão, e aceita uma função filter opcional para limitar por propriedades de entradas. Isso te permite buscar apenas alguns itens em uma coleção com base no id, slug, ou valores do frontmatter pelo objeto data.

---
import { getCollection } from 'astro:content';
// Pega todas as entradas de `src/content/blog/`
const todasPostagensBlog = await getCollection('blog');
// Apenas retorna postagens com `draft: true` no frontmatter
const postagensRascunhoBlog = await getCollection('blog', ({ data }) => {
return data.draft === true;
});
---

Veja a seção guia de getCollection() para exemplos completos de uso.

Adicionado em: astro@2.5.0

Tipos:

  • (collection: string, contentSlugOrDataId: string) => CollectionEntry<collection>
  • ({ collection: string, id: string }) => CollectionEntry<collection>
  • ({ collection: string, slug: string }) => CollectionEntry<collection>

getEntry() é uma função que recupera uma única entrada de coleção pelo nome da coleção e tanto pelo id da entrada (para coleções type: 'data') ou pelo slug da entrada (para coleções type: 'content'). getEntry() também pode ser usada para obter entradas referenciadas para acessar as propriedades data, body ou render():

---
import { getEntry } from 'astro:content';
// Obtém `src/content/blog/empreendimento.md`
const empreendimentoPostagem = await getEntry('blog', 'empreendimento');
// Obtém `src/content/capitaes/picard.yaml`
const picardPerfil = await getEntry('capitaes', 'picard');
// Obtém o perfil referenciado por `data.capitao`
const empreendimentoCapitaoPerfil = await getEntry(empreendimento.data.capitao);
---

Veja o guia Coleções de Conteúdo para exemplos de como consultar entradas de coleção.

Adicionado em: astro@2.5

Tipos:

  • (Array<{ collection: string, id: string }>) => CollectionEntry<collection>
  • (Array<{ collection: string, slug: string }>) => CollectionEntry<collection>

getEntries() é uma função que recupera múltiplas entradas de uma mesma coleção. Isso é útil para retornar um array de entradas referenciadas para acessar as propriedades data, body e render() associadas a elas.

---
import { getEntries } from 'astro:content';
const empreendimentoPostagem = await getEntry('blog', 'empreendimento');
// Obtém postagens relacionadas referenciadas por `data.postagensRelacionadas`
const empreendimentoPostagensRelacionadas = await getEntries(empreendimentoPostagem.data.postagensRelacionadas);
---

Tipo: (collection: string, slug: string) => CollectionEntry<collection>

getEntry() é uma função que devolve uma única entrada de coleção por nome de coleção e slug da entrada.

---
import { getEntryBySlug } from 'astro:content';
const enterprise = await getEntryBySlug('blog', 'enterprise');
---

Veja o guia de Coleções de Conteúdo para exemplos de uso.

As funções de consulta getCollection(), getEntry() e getEntries() retornam entradas com o tipo CollectionEntry. Esse tipo está disponível como um utilitário de astro:content:

import type { CollectionEntry } from 'astro:content';

O tipo CollectionEntry<TCollectionName> é um objeto com os seguintes valores. TCollectionName é o nome da coleção que você está consultando (e.x. CollectionEntry<'blog'>).

Disponível para: coleções type: 'content' e type: 'data' Tipos de Exemplo:

  • coleções de conteúdo: 'entrada-1.md' | 'entrada-2.md' | ...
  • coleções de dados: 'autor-1' | 'autor-2' | ...

Um ID único utilizando o caminho de arquivo relativo a src/content/[coleção]. Enumera todos os valores de string possíveis com base nos caminhos de arquivo da entrada de coleção. Note que coleções definidas como type: 'content' incluem a extensão do arquivo em seus ID, enquanto coleções definidas como type: 'data' nao incluem.

Disponível para: coleções type: 'content' e type: 'data' Tipo de Exemplo: 'blog' | 'autores' | ...

O nome de uma pasta de nível superior dentro de src/content/ onde as entradas são localizadas. Este é o nome usado para referenciar a coleção no seu esquema e em funções de consulta.

Disponível para: coleções type: 'content' e type: 'data' Tipo: CollectionSchema<TCollectionName>

Um objeto de propriedades frontmatter inferidas do schema da sua coleção (veja a referência de defineCollection()). Por padrão é any se nenhum schema é configurado.

Disponível para: apenas coleções type: 'content' Tipo de Exemplo: 'entrada-1' | 'entrada-2' | ...

Uma slug pronta para URLs para documentos Markdown ou MDX. Por padrão é o id sem a extensão de arquivo, mas pode ser sobreescrita ao definir a propriedade slug no frontmatter de um arquivo.

Disponível para: apenas coleções type: 'content' Tipo: string

Uma string contendo o body bruto e não-compilado do documento Markdown ou MDX.

Disponível para: apenas coleções type: 'content' Tipo: () => Promise<RenderedEntry>

Uma função para compilar dado documento Markdown ou MDX document para renderização. Ela retorna as seguintes propriedades:

---
import { getEntryBySlug } from 'astro:content';
const entry = await getEntryBySlug('blog', 'entry-1');
const { Content, headings, remarkPluginFrontmatter } = await entry.render();
---

Veja a seção guia de getCollection() para exemplos completos de uso.

Outros tipos de Coleções de Conteúdo

Seção intitulada Outros tipos de Coleções de Conteúdo

O módulo astro:content também exporta os seguintes tipos para utilizar em seu projeto Astro:

Uma união de strings de todos os nomes de coleções definidas em seu arquivo src/content/config.*. Esse tipo pode ser útil ao definir uma função genérica que aceite o nome de qualquer coleção.

import type { CollectionKey, getCollection } from 'astro:content';
async function getCollection(collection: CollectionKey) {
return getCollection(collection);
}

Uma união de strings de todos os nomes de coleções type: 'content' definidos em seu arquivo src/content/config.*.

Uma união de strings de todos os nomes de coleções type: 'data' definidoes em seu arquivo src/content/config.*.

O objeto context que defineCollection passa para a construção do schema. Esse tipo pode ser útil ao criar schemas reutilizáveis para múltiplas coleções.

Isso inclui as seguintes propriedades:

import type { SchemaContext } from 'astro:content';
export const imageSchema = ({ image }: SchemaContext) =>
z.object({
image: image(),
description: z.string().optional(),
});
const blog = defineCollection({
type: 'content',
schema: ({ image }) => z.object({
title: z.string(),
permalink: z.string().optional(),
image: imageSchema({ image }),
}),
});

Adicionado em: astro@2.6.0

Middleware lhe permite interceptar chamadas e respostas e injetar comportamentos dinamicamente cada vez que uma página ou endpoint estiver prestes ser renderizada. Para funcionalidades e exemplos de uso, veja nosso guia sobre middleware.

Uma função exportada obrigatória do arquivo src/middleware.js que será chamada antes da renderização de cada página ou rota da API. Ela aceita dois argumentos opcionais: context e next(). onRequest() deve retornar uma Response: ou diretamente, ou chamando next().

src/middleware.js
export function onRequest(context, next) {
// intercepta dados da chamada
// opcionalmente, transforma a resposta
// retorna uma `Response` diretamente, ou o resultado de chamar `next()`
return next();
}

Uma função que intercepta (lê e modifica) a resposta (Response) de uma requisição (Request) ou invoca o próximo middleware na sequência e retorna uma Response. Por exemplo, essa função pode modificar o corpo HTML de uma resposta.

Esse é um argumento opcional de onRequest(), e pode prover a Response que o middleware deve retornar.

Uma função que aceita funções de middleware como argumentos, e os executará na ordem que foram passados.

src/middleware.js
import { sequence } from "astro:middleware";
async function valida(_, next) {...}
async function autentica(_, next) {...}
async function sauda(_, next) {...}
export const onRequest = sequence(valida, autentica, sauda);

Uma API de baixo nível para criar um APIContext que pode ser utilizado pelo middleware Astro.

Essa função pode ser usada por integrações/adaptadores para executar programaticamente os middlewares Astro.

Uma API de baixo nível que recebe qualquer valor e tenta retornar uma versão serializada (uma string) desse valor. Se o valor não puder ser serializado, essa função irá lançar um erro de runtime.

Astro inclui vários componentes integrados para você utilizar em seus projetos. Todos os componentes integrados estão disponíveis em arquivos .astro via import {} from 'astro:components';.

---
import { Code } from 'astro:components';
---
<!-- Adicione syntax highlight de algum código JavaScript. -->
<Code code={`const foo = 'bar';`} lang="js" />
<!-- Opcional: Customize seu tema. -->
<Code code={`const foo = 'bar';`} lang="js" theme="dark-plus" />
<!-- Opcional: Habilite quebra de texto. -->
<Code code={`const foo = 'bar';`} lang="js" wrap />
<!-- Optional: Exiba código em linha. -->
<p>
<Code code={`const foo = 'bar';`} lang="js" inline />
vai ser renderizado em linha.
</p>

Este componente providencia syntax highlighting para blocos de código em tempo de build (sem JavaScript no lado do cliente). O componente é viabilizado internamente por Shiki e suporta todos os temas e linguagens populares. Além disso, você pode adicionar temas e linguagens customizadas as passando para theme e lang respectivamente.

Um componente utilizado com diretivas set:* para renderizar conteúdo HTML sem nenhum elemento adicional em volta:

src/components/SetHtml.astro
---
const htmlString = '<p>Raw HTMl content</p>';
---
<Fragment set:html={htmlString} />

Veja mais sobre o uso de fragmentos na sintaxe do Astro.

Para usar o componente highlighter Prism, primeiro instale o pacote @astrojs/prism:

Terminal window
npm install @astrojs/prism
---
import { Prism } from '@astrojs/prism';
---
<Prism lang="js" code={`const foo = 'bar';`} />

Este componente providencia syntax highlighting de linguagens específicas para blocos de código aplicando as classes CSS do Prism. Note que você precisa providenciar uma folha de estilos CSS do Prism (ou utilizar sua própria) para aparecer o syntax highlighting! Veja a seção de configuração do Prism para mais detalhes.

Veja a lista de linguagens suportadas pelo Prism aonde você pode ver o alias correspondente de uma linguagem. E, você também pode mostrar seus blocos de código Astro com lang="astro"!

src/components/MeuComponente.astro
---
// Importe o componente Image e a imagem
import { Image } from "astro:assets";
import minhaImagem from "../assets/minha_imagem.png"; // Imagem é 1600x900
---
<!-- `alt` é obrigatório no componente Image -->
<Image src={minhaImagem} alt="Uma descrição da minha imagem." />
<!-- Output -->
<!-- Image é otimizado, atributos apropriados são garantidos -->
<img
src="/_astro/minha_imagem.hash.webp"
width="1600"
height="900"
decoding="async"
loading="lazy"
alt="Uma descrição da minha imagem."
/>
  • src (obrigatório)
  • alt (obrigatório)
  • width e height (obrigatórios para imagens em public/ ou remotas)
  • format
  • quality
  • densities
  • widths

Adicionalmente às propriedades acima, o componente <Image /> aceita todas as propriedades da tag HTML <img>.

Veja mais detalhes no Guia de Imagens.

Adicionado em: astro@3.3.0

Use o componente Astro integrado <Picture /> para exibir imagens responsivas com múltiplos formatos e/ou tamanhos.

src/pages/index.astro
---
import { Picture } from "astro:assets";
import minhaImagem from "../assets/minha_imagem.png"; // Imagem é 1600x900
---
<!-- `alt` é obrigatório no componente Image -->
<Picture src={minhaImagem} formats={['avif', 'webp']} alt="Uma descrição da minha imagem." />
<!-- Output -->
<picture>
<source srcset="/_astro/minha_imagem.hash.avif" type="image/avif" />
<source srcset="/_astro/minha_imagem.hash.webp" type="image/webp" />
<img
src="/_astro/minha_imagem.hash.png"
width="1600"
height="900"
decoding="async"
loading="lazy"
alt="Uma descrição da minha imagem."
/>
</picture>

Veja mais no Guia de Imagens.

<Picture /> aceita todas as propriedades do componente <Image />, juntamente com:

Um array de formatos de imagem a serem utilizados nas tags <source>. Por padrão, isso é configurado como ['webp'].

Formato a ser usado como um valor de fallback para a tag <img>. Por padrão, é configurado como .png para imagens estáticas, .gif para imagens animadas e .svg para arquivos SVG.

Use essa propriedade para aplicar atributos ao elemento externo <picture>. Atributos aplicados diretamente ao componente <Picture /> serão aplicados internamente ao elemento <img>, exceto aqueles usados para a transformação da imagem.

Um componente genérico utilizado para renderizar o conteúdo de uma entrada de uma coleção de conteúdo.

Primeiro, busque por uma ou mais entradas utilizando getCollection() ou getEntry(). Com isso, a função entrada.render() pode retornar o componente <Content /> para ser utilizado em um arquivo de template .astro.

src/pages/render-example.astro
---
import { getEntry } from "astro:content";
const entrada = await getEntry('blog', 'post-1');
const { Content } = await entrada.render();
---
<p>Publicado em: {entrada.data.publicado.toDateString()}</p>
<Content />

Opte por usar transições de visualização on páginas individuais importando e adicionando o componente de roteamento <ViewTransitions /> ao <head> em cada página desejada.

src/pages/index.astro
---
import { ViewTransitions } from "astro:transitions";
---
<html lang="en">
<head>
<title>Minha página inicial</title>
<ViewTransitions />
</head>
<body>
<h1>Bem-vindo ao meu site!</h1>
</body>
</html>

Veja mais sobre como controlar o roteamento e adicionar diretivas de transição em elementos e componentes da página.

---
import { Debug } from 'astro:components';
const objetoDoServidor = {
a: 0,
b: "string",
c: {
aninhado: "objeto"
}
}
---
<Debug {objetoDoServidor} />

Este componente providencia uma forma de inspecionar valores no lado do cliente, sem utilizar JavaScript.

Contribua

O que passa em sua cabeça?

Comunidade