Páginas
Páginas são arquivos que vivem dentro do subdiretório src/pages/
do seu projeto Astro. Elas são responsáveis por manipular o roteamento, o carregamento de dados e com o layout de toda página do seu website.
Tipos de arquivos suportados
Seção intitulada Tipos de arquivos suportadosAstro suporta os seguintes tipos de arquivo no diretório src/pages/
:
.astro
.md
.mdx
(com a Integração MDX instalada (EN)).html
- [
.js
/.ts
] (como endpoints)
Roteamento baseado em arquivos
Seção intitulada Roteamento baseado em arquivosAstro aproveita uma estratégia de roteamento chamada roteamento baseado em arquivos. Cada arquivo no diretório src/pages
torna-se um endpoint no site com base no caminho do arquivo.
Um único arquivo também pode gerar múltiplas páginas utilizando roteamento dinâmico. Isso permite que você crie páginas mesmo que seu conteúdo esteja fora do diretório especial /pages/
, como em uma coleção de conteúdo ou em um CMS.
Link entre páginas
Seção intitulada Link entre páginasEscreva elementos <a>
padrão HTML em suas páginas Astro para ligar a outras páginas no site. Utilize como link o caminho URL relativo ao domínio raiz, não um caminho de arquivo relativo.
Por exemplo, para acessar https://exemplo.com/autores/sonali/
de qualquer outra página dentro de exemplo.com
:
Páginas Astro
Seção intitulada Páginas AstroPáginas Astro usam a extensão de arquivo .astro
e suportam as mesmas funcionalidades que componentes Astro.
Uma página deve produzir um documento HTML completo. Se não for explicitamente incluído, Astro adicionará a declaração <!DOCTYPE html>
necessária e conteúdo <head>
em qualquer componente .astro
localizado em src/pages/
por padrão. Você pode optar não utilizar esse comportamento de maneira individual por componente, marcando-o como uma página parcial.
Para evitar repetir os mesmos elementos HTML em cada página, você pode mover elementos <head>
e <body>
comuns em seus próprios componentes de layout. Você pode usar quantos componentes de layout você quiser.
Páginas Markdown/MDX
Seção intitulada Páginas Markdown/MDXAstro trata quaisquer arquivos Markdown (.md
) dentro de src/pages/
como páginas em seu site final. Se você tiver a Integração MDX instalada (EN), ele tratará arquivos MDX (.mdx
) da mesma forma.
Considere criar coleções de conteúdo em vez de páginas para diretórios de arquivos Markdown relacionados que partilham estrutura similar, como posts de blog ou produtos.
Arquivos Markdown podem usar a propriedade frontmatter especial layout
para especificar um layout de componente que envolverá o conteúdo Markdown em um documento <html>...</html>
.
Páginas HTML
Seção intitulada Páginas HTMLArquivos com a extensão .html
podem ser colocados dentro de src/pages/
e usados diretamente como páginas no seu site. Note que algumas funcionalidades-chave Astro não funcionam em Componentes HTML.
Página de Erro 404 Personalizada
Seção intitulada Página de Erro 404 PersonalizadaPara uma página de erro 404 personalizada, você pode criar um arquivo 404.astro
ou 404.md
em src/pages
.
Isso construirá uma página 404.html
. A maioria dos serviços de deploy irão encontrá-la e utilizá-la.
Página de Erro 500 Personalizada
Seção intitulada Página de Erro 500 PersonalizadaPara uma página de erro 500 personalizada aparecer para páginas que são geradas sob demanda, crie o arquivo src/pages/500.astro
. Essa página personalizada não está disponível para páginas pré-geradas e não podem ser geradas previamente.
Se um erro ocorrer ao gerar essa página, a página padrão da sua hospedagem será mostrada ao visitante.
Adicionado em:
astro@4.10.3
Durante o desenvolvimento, se você tiver um 500.astro
, o erro lançado em tempo de execução é registrado em seu terminal, em vez de ser mostrado na janela de erros.
Adicionado em:
astro@4.11.0
src/pages/500.astro
é uma página especial que recebe automaticamente uma prop error
para qualquer erro lançado durante a apresentação. Isso permite que você use os detalhes de um erro (como de uma página, de um middleware, etc.) para mostrar informações ao seu visitante.
O tipo de dado da prop error pode ser qualquer coisa, que pode afetar como você tipa ou usa o valor no seu código:
Para evitar vazar informações snsíveis ao mostrar o conteúdo da prop error
, considere avaliar o erro primeiro, e retornar o conteúdo apropriado baseado no erro lançado. Por exemplo, você deve evitar mostrar a pilha do erro pois ela contém informações sobre como seu código é estruturado no servidor
Parciais de páginas
Seção intitulada Parciais de páginas
Adicionado em:
astro@3.4.0
Parciais de páginas são projetadas para serem utlizadas em conjunto com uma biblioteca front-end, como htmx ou Unpoly. Você também pode usá-las caso se sinta confortável escrevendo front-end JavaScript em baixo nível. Por esse motivo são um recurso avançado.
Adicionalmente, parciais não devem ser usadas se o componente contém estilos em escopo ou scripts, pois esses elementos serão removidos do HTML gerado. Se você precisa de estilos em escopo, é melhor utilizar páginas não-parciais regulares em conjunto com uma biblioteca front-end que saiba mesclar conteúdos ao head.
Parciais são componentes de página localizados em src/pages/
que não têm como objetivo serem apresentados como páginas completas.
Como componentes localizados fora dessa pasta, esses arquivos não incluem automaticamente a declaração <!DOCTYPE html>
, nem qualquer outro conteúdo do <head>
como estilos em escopo e scripts.
Entretanto, por estarem localizados no diretório especial src/pages/
, o HTML gerado fica disponível em uma URL que corresponde ao caminho do arquivo. Isso permite que uma biblioteca de renderização (como htmx, Stimulus, jQuery) possa acessá-lo no cliente e carregar seções do HTML dinamicamente em uma página sem recarregar o navegador ou navegar entre páginas.
Parciais, quando combinados com uma biblioteca de renderização, proporcionam uma alternativa às Ilhas Astro e tags <script>
na construção de conteúdo dinâmico em Astro.
Arquivos de página que podem exportar um valor (ex: .astro
, .mdx
) podem ser marcadas como parciais.
Configure um arquivo no diretório src/pages/
para ser uma parcial adicionando a seguinte exportação:
O export const partial
deve ser identificável estaticamente. Ele pode ter o valor de:
- O booleano
true
. - Uma variável de ambiente usando import.meta.env como
import.meta.env.USE_PARTIALS
.
Usando com uma biblioteca
Seção intitulada Usando com uma bibliotecaParciais são usadas para atualizar dinamicamente a seção de uma página usando bibliotecas como htmx.
O exemplo a seguir mostra um atributo hx-post
direcionado para a URL de uma parcial. O conteúdo da página parcial será usado para atualizar o elemento HTML escolhido na página.
A parcial .astro
deve existir no caminho correspondente e incluir uma exportação definindo a página como uma parcial.
Visite a documentação htmx para mais detalhes sobre como utilizar htmx.
Learn