import{_ as t,c as l,ag as i,j as a,a as n,G as p,B as h,o as k}from"./chunks/framework.C1C4sYC0.js";const F=JSON.parse('{"title":"Configuração do Site","description":"","frontmatter":{"outline":"deep"},"headers":[],"relativePath":"pt/reference/site-config.md","filePath":"pt/reference/site-config.md","lastUpdated":1736537361000}'),o={name:"pt/reference/site-config.md"},r={id:"mpa",tabindex:"-1"};function d(c,s,g,E,u,y){const e=h("Badge");return k(),l("div",null,[s[3]||(s[3]=i(`
A configuração do site é onde você pode definir as configurações globais do site. As opções de configuração do aplicativo definem configurações que se aplicam a todos os sites VitePress, independentemente do tema que estão usando. Por exemplo, o diretório base ou o título do site.
O arquivo de configuração é sempre resolvido a partir de <root>/.vitepress/config.[ext], onde <root> é a raiz do projeto VitePress e [ext] é uma das extensões de arquivo suportadas. O TypeScript é suportado de fábrica. As extensões suportadas incluem .js, .ts, .mjs e .mts.
Recomenda-se usar a sintaxe de módulos ES nos arquivos de configuração. O arquivo de configuração deve exportar por padrão um objeto:
export default {
// opções de configuração de nível da aplicação
lang: 'pt-BR',
title: 'VitePress',
description: 'Gerador de site estático Vite & Vue.',
...
}Se você precisar gerar dinamicamente a configuração, também pode exportar por padrão uma função. Por exemplo:
import { defineConfig } from 'vitepress'
export default async () => {
const posts = await (await fetch('https://my-cms.com/blog-posts')).json()
return defineConfig({
// opções de configuração de nível da aplicação
lang: 'pt-BR',
title: 'VitePress',
description: 'Gerador de site estático Vite & Vue.',
// opções de configuração de nível do tema
themeConfig: {
sidebar: [
...posts.map((post) => ({
text: post.name,
link: \`/posts/\${post.name}\`
}))
]
}
})
}Você também pode usar o await no nível superior. Como:
import { defineConfig } from 'vitepress'
const posts = await (await fetch('https://my-cms.com/blog-posts')).json()
export default defineConfig({
// opções de configuração de nível da aplicação
lang: 'pt-BR',
title: 'VitePress',
description: 'Gerador de site estático Vite & Vue.',
// opções de configuração de nível do tema
themeConfig: {
sidebar: [
...posts.map((post) => ({
text: post.name,
link: \`/posts/\${post.name}\`
}))
]
}
})Usar o auxiliar defineConfig fornecerá Intellisense alimentado por TypeScript para as opções de configuração. Supondo que seu IDE o suporte, isso deve funcionar tanto em JavaScript quanto em TypeScript.
import { defineConfig } from 'vitepress'
export default defineConfig({
// ...
})Por padrão, o auxiliar defineConfig espera o tipo de configuração de tema do tema padrão:
import { defineConfig } from 'vitepress'
export default defineConfig({
themeConfig: {
// O tipo é \`DefaultTheme.Config\`
}
})Se você estiver usando um tema personalizado e desejar verificações de tipo para a configuração do tema, será necessário usar defineConfigWithTheme em vez disso, e passar o tipo de configuração para o seu tema personalizado por meio de um argumento genérico:
import { defineConfigWithTheme } from 'vitepress'
import type { ThemeConfig } from 'your-theme'
export default defineConfigWithTheme<ThemeConfig>({
themeConfig: {
// O tipo é \`ThemeConfig\`
}
})Vite
Você pode configurar a instância subjacente do Vite usando a opção vite em sua configuração VitePress. Não é necessário criar um arquivo de configuração Vite separado.
Vue
VitePress já inclui o plugin Vue oficial para Vite (@vitejs/plugin-vue). Você pode configurar suas opções usando a opção vue em sua configuração VitePress.
Markdown
Você pode configurar a instância subjacente de Markdown-It usando a opção markdown em sua configuração VitePress.
stringVitePressTítulo do site. Ao usar o tema padrão, isso será exibido na barra de navegação.
Ele também será usado como o sufixo padrão para todos os títulos individuais das páginas, a menos que titleTemplate seja definido. O título final de uma página individual será o conteúdo textual do seu primeiro cabeçalho <h1>, combinado com o título global como sufixo. Por exemplo, com a seguinte configuração e conteúdo da página:
export default {
title: 'Meu Site Incrível'
}# OláO título da página será Olá | Meu Site Incrível.
string | booleanPermite personalizar o sufixo do título de cada página ou o título inteiro. Por exemplo:
export default {
title: 'Meu Site Incrível',
titleTemplate: 'Sufixo Personalizado'
}# OláO título da página será Olá | Sufixo Personalizado.
Para personalizar completamente como o título deve ser renderizado, você pode usar o símbolo :title em titleTemplate:
export default {
titleTemplate: ':title - Sufixo Personalizado'
}Aqui, :title será substituído pelo texto inferido do primeiro cabeçalho <h1> da página. O título do exemplo anterior da página será Olá - Sufixo Personalizado.
A opção pode ser definida como false para desativar sufixos de título.
stringUm site VitePressDescrição para o site. Isso será apresentado como uma tag <meta> na página HTML.
export default {
descrição: 'Um site VitePress'
}HeadConfig[][]Elementos adicionais para adicionar na tag <head> da página HTML. As tags adicionadas pelo usuário são mostradas antes da tag head de fechamento, após as tags VitePress.
type HeadConfig =
| [string, Record<string, string>]
| [string, Record<string, string>, string]export default {
cabeça: [['link', { rel: 'icon', href: '/favicon.ico' }]]
} // coloque o favicon.ico no diretório public, se a base estiver definida, use /base/favicon.ico
/* Mostraria:
<link rel="icon" href="/favicon.ico">
*/export default {
head: [
[
'link',
{ rel: 'preconnect', href: 'https://fonts.googleapis.com' }
],
[
'link',
{ rel: 'preconnect', href: 'https://fonts.gstatic.com', crossorigin: '' }
],
[
'link',
{ href: 'https://fonts.googleapis.com/css2?family=Roboto&display=swap', rel: 'stylesheet' }
]
]
}
/* Mostraria:
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Roboto&display=swap" rel="stylesheet">
*/export default {
head: [
[
'script',
{ id: 'register-sw' },
\`;(() => {
if ('serviceWorker' in navigator) {
navigator.serviceWorker.register('/sw.js')
}
})()\`
]
]
}
/* Mostraria:
<script id="register-sw">
;(() => {
if ('serviceWorker' in navigator) {
navigator.serviceWorker.register('/sw.js')
}
})()
</script>
*/export default {
head: [
[
'script',
{ async: '', src: 'https://www.googletagmanager.com/gtag/js?id=TAG_ID' }
],
[
'script',
{},
\`window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'TAG_ID');\`
]
]
}
/* Mostraria:
<script async src="https://www.googletagmanager.com/gtag/js?id=TAG_ID"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'TAG_ID');
</script>
*/stringen-USO atributo de idioma para o site. Isso será mostrado como uma tag <html lang="en-US"> na página HTML.
export default {
lang: 'en-US'
}string/A URL base em que o site será implantado. Você precisará definir isso se planeja implantar seu site em um subdiretório, por exemplo, no GitHub pages. Se você planeja implantar seu site em https://foo.github.io/bar/ então você deve definir a base como '/bar/'. Deve sempre começar e terminar com uma barra.
A base é automaticamente adicionada a todos as URLs que começam com / em outras opções, então você só precisa especificá-la uma vez.
export default {
base: '/base/'
}booleanfalseQuando definido como true, VitePress removerá o .html no final dos URLs. Veja também Gerando URL Limpa.
Suporte do Servidor Necessário
Ativar isso pode exigir configurações adicionais em sua plataforma de hospedagem. Para funcionar, seu servidor deve ser capaz de servir /foo.html ao visitar /foo sem redirecionamento.
Record<string, string>Define mapeamentos personalizados de diretório <-> URL. Veja Roteamento: Reescrever Rotas para mais detalhes.
export default {
rewrites: {
'source/:page': 'destination/:page'
}
}string.O diretório onde suas páginas de markdown são armazenadas, relativo à raiz do projeto. Veja também Diretório Raiz e Fonte.
export default {
srcDir: './src'
}stringundefinedUm padrão glob para corresponder a arquivos markdown que devem ser excluídos como conteúdo fonte.
export default {
srcExclude: ['**/README.md', '**/TODO.md']
}string./.vitepress/distA localização da saída da compilação para o site, relativa à raiz do projeto.
export default {
outDir: '../public'
}stringassetsEspecifica o diretório para aninhar ativos gerados. O caminho deve estar dentro de outDir e é resolvido em relação a ele.
export default {
assetsDir: 'static'
}string./.vitepress/cacheO diretório para arquivos de cache, relativo à raiz do projeto. Veja também: cacheDir.
export default {
cacheDir: './.vitepress/.vite'
}boolean | 'localhostLinks' | (string | RegExp | ((link: string) => boolean))[]falseQuando definido como true, VitePress não falhará na compilação devido a links quebrados.
Quando definido como 'localhostLinks', a compilação falhará em links quebrados, mas não verificará links localhost.
export default {
ignoreDeadLinks: true
}Também pode ser um array de uma exata URL em string, padrões regex, ou funções de filtro personalizadas.
export default {
ignoreDeadLinks: [
// ignora URL exata "/playground"
'/playground',
// ignora todos os links localhost
/^https?:\\/\\/localhost/,
// ignora todos os links incluindo "/repl/""
/\\/repl\\//,
// função personalizada, ignora todos os links incluindo "ignore"
(url) => {
return url.toLowerCase().includes('ignore')
}
]
}booleanfalseQuando definido como true, a aplicação em produção será compilada no Modo MPA. O modo MPA envia 0kb de JavaScript por padrão, às custas de desabilitar a navegação no lado do cliente e exigir permissão explícita para interatividade.
boolean | 'dark' | 'force-dark' | import('@vueuse/core').UseDarkOptionstrueSe habilitar o modo escuro (adicionando a classe .dark ao elemento <html>).
true o tema padrão é determinado pelo esquema de cores preferido do usuário.dark o tema é escuro por padrão, a menos que o usuário mude manualmente.false os usuários não poderão mudar o tema.Esta opção injeta um script em linha que restaura as configurações dos usuários do armazenamento local (local storage) usando a chave vitepress-theme-appearance. Isso garante que a classe .dark seja aplicada antes de a página ser mostrada para evitar oscilações.
appearance.initialValue só pode ser 'dark' | undefined. Refs ou getters não são suportados.
booleanfalsePara obter o selo de tempo da última atualização para cada página usando o Git. O selo de data será incluído nos dados de cada página, acessíveis via useData.
Ao usar o tema padrão, habilitar esta opção exibirá o horário da última atualização de cada página. Você pode personalizar o texto via opção themeConfig.lastUpdatedText.
MarkdownOptionConfigure as opções do processador Markdown. VitePress usa Markdown-it como processador e Shiki para destacar sintaxe de linguagem. Dentro desta opção, você pode passar várias opções Markdown relacionadas para atender às suas necessidades.
export default {
markdown: {...}
}Verifique a declaração de tipo e jsdocs para todas as opções disponíveis.
import('vite').UserConfigPasse a Configuração Vite crua para o servidor interno / empacotador Vite.
export default {
vite: {
// Opções de configuração Vite
}
}import('@vitejs/plugin-vue').OptionsPasse as opções @vitejs/plugin-vue cruas para a instância interna do plugin.
export default {
vue: {
// Opções @vitejs/plugin-vue
}
}Os ganchos de compilação VitePress permitem adicionar novas funcionalidades ao seu site:
(siteConfig: SiteConfig) => Awaitable<void>buildEnd é um gancho de compilação CLI (Interface de Linha de Comando), ele será executado após a conclusão da compilação (SSG), mas antes que o processo VitePress CLI termine.export default {
async buildEnd(siteConfig) {
// ...
}
}Tipo: (context: SSGContext) => Awaitable<SSGContext | void>
postRender é um gancho de compilação, chamado quando a interpretação SSG é concluída. Ele permitirá que você manipule o conteúdo de teleports durante a geração de site estático.
export default {
async postRender(context) {
// ...
}
}interface SSGContext {
content: string
teleports?: Record<string, string>
[key: string]: any
}(context: TransformContext) => Awaitable<HeadConfig[]>transformHead é um gancho de compilação para transformar o cabeçalho antes de gerar cada página. Isso permite adicionar entradas no cabeçalho que não podem ser adicionadas estaticamente à configuração VitePress. Você só precisa retornar entradas extras, que serão mescladas automaticamente com as existentes.
WARNING
Não faça mutações em qualquer item dentro de context.
export default {
async transformHead(context) {
// ...
}
}interface TransformContext {
page: string // e.g. index.md (relativo a srcDir)
assets: string[] // todos os ativos não-js/css com URL pública completamente resolvida
siteConfig: SiteConfig
siteData: SiteData
pageData: PageData
title: string
description: string
head: HeadConfig[]
content: string
}Note que este gancho só é chamado ao gerar o site estaticamente. Não é chamado durante o desenvolvimento. Se você precisar adicionar entradas de cabeçalho dinâmicas durante o desenvolvimento, pode usar o gancho transformPageData em seu lugar.
export default {
transformPageData(pageData) {
pageData.frontmatter.head ??= []
pageData.frontmatter.head.push([
'meta',
{
name: 'og:title',
content:
pageData.frontmatter.layout === 'home'
? \`VitePress\`
: \`\${pageData.title} | VitePress\`
}
])
}
}<link> export default {
transformPageData(pageData) {
const canonicalUrl = \`https://example.com/\${pageData.relativePath}\`
.replace(/index\\.md$/, '')
.replace(/\\.md$/, '.html')
pageData.frontmatter.head ??= []
pageData.frontmatter.head.push([
'link',
{ rel: 'canonical', href: canonicalUrl }
])
}
}(code: string, id: string, context: TransformContext) => Awaitable<string | void>transformHtml é um gancho de compilação para transformar o conteúdo de cada página antes de salvá-lo no disco.WARNING
Não faça mutações em qualquer item dentro de context. Além disso, modificar o conteúdo HTML pode causar problemas de hidratação em tempo de execução.
export default {
async transformHtml(code, id, context) {
// ...
}
}(pageData: PageData, context: TransformPageContext) => Awaitable<Partial<PageData> | { [key: string]: any } | void>transformPageData é um gancho para transformar os dados de cada página. Você pode fazer mutações diretamente em pageData ou retornar valores alterados que serão mesclados nos dados da página.
WARNING
Não faça mutações em qualquer item dentro de context e tenha cuidado pois isso pode impactar no desempenho do servidor de desenvolvimento, especialmente se você tiver algumas solicitações de rede ou computações pesadas (como gerar imagens) no gancho. Você pode verificar process.env.NODE_ENV === 'production' para lógica condicional.
export default {
async transformPageData(pageData, { siteConfig }) {
pageData.contributors = await getPageContributors(pageData.relativePath)
}
// ou retorne dados a serem mesclados
async transformPageData(pageData, { siteConfig }) {
return {
contributors: await getPageContributors(pageData.relativePath)
}
}
}interface TransformPageContext {
siteConfig: SiteConfig
}