Faça sua pergunta e obtenha um resumo do documento referenciando esta página e o provedor AI de sua escolha
Histórico de versões
- "Init history"v8.13.005/06/2026
O conteúdo desta página foi traduzido com uma IA.
Veja a última versão do conteúdo original em inglêsIf you have an idea for improving this documentation, please feel free to contribute by submitting a pull request on GitHub.
GitHub link to the documentationCopy doc Markdown to clipboard
Migrando de @nuxtjs/i18n para Intlayer
Por que migrar de @nuxtjs/i18n para Intlayer?
Em vez de carregar enormes arquivos JSON em suas páginas, carregue apenas o conteúdo necessário. Intlayer ajuda você a reduzir o tamanho do pacote e da página em até 50%.
Criar escopos para o conteúdo da sua aplicação torna aplicações em larga escala fáceis de manter. Você pode duplicar ou excluir um diretório de recursos inteiro sem o esforço mental de revisar toda a sua base de código de conteúdo. Além disso, Intlayer é fortemente tipado para garantir a precisão do seu conteúdo.
Intlayer também é a solução desenvolvida mais ativamente no ecossistema i18n — problemas são corrigidos rapidamente, novos adaptadores de frameworks são lançados regularmente e a API principal é continuamente refinada com base em feedback do mundo real em produção.
A co-localização do conteúdo reduz o contexto necessário para Modelos de Linguagem de Grande Escala (LLMs). O Intlayer também oferece um conjunto de ferramentas como uma CLI para testar traduções ausentes, LSP, MCP e Habilidades de Agente para tornar a Experiência do Desenvolvedor (DX) muito mais suave para agentes de IA.
Automatize as traduções em seu pipeline de CI/CD usando o LLM de sua preferência pelo custo do seu provedor de IA. O Intlayer também oferece um compilador para automatizar a extração de conteúdo, bem como uma plataforma web para auxiliar com tradução em segundo plano.
Conectar enormes arquivos JSON aos componentes pode levar a problemas de desempenho e reatividade. O Intlayer otimiza o carregamento do conteúdo no momento do build (build time).
Muito mais que apenas uma solução i18n, o Intlayer fornece um editor visual auto-hospedável e um CMS completo para ajudá-lo a gerenciar seu conteúdo multilíngue em tempo real, tornando perfeita a colaboração com tradutores, redatores e outros membros da equipe. O conteúdo pode ser armazenado local e/ou remotamente.
Estratégias de Migração
Como o @nuxtjs/i18n é executado usando vue-i18n sob o capô, há duas estratégias complementares para migrar para o Intlayer:
Adaptador de Compatibilidade (Recomendado para apps existentes) — Instale o
@intlayer/vue-i18ne onuxt-intlayer. Isso expõe exatamente a mesma API que ovue-i18n, delegando todo o trabalho de tradução de bastidores para o Intlayer. Mantenha intactas suas chamadas para$t,useI18n()e do roteador do Nuxt — a única alteração é a inicialização.Migração Completa — Substitua de forma progressiva a API contida no
@nuxtjs/i18nvoltando-se aos hooks integrados nativos vinculados e oferecidos pelo uso do Intlayer (useIntlayer) assim como, de carona no mesmo conceito de trabalho, vá colocalizando tudo relacionado a conteúdo e variáveis diretamente sob arquivos.content.tsperto a proximidade de seus respectivos componentes.
Este guia foca inicialmente em tratar a fundo a Estratégia 1 (que aborda o uso rápido através do tal adaptador de compatibilidade em substituição direta) antes de mergulhar na completa migração, opcional em questão.
Índice
Migração Rápida
As etapas a seguir são o mínimo necessário para executar seu aplicativo Nuxt existente no Intlayer, sem fazer alterações no código de seus componentes.
Instale as Dependências
Instale o pacote principal do Intlayer e o adaptador de compatibilidade:
bashCopiar códigoCopiar o código para a área de transferência
npm install intlayer vue-intlayer nuxt-intlayer @intlayer/vue-i18n @intlayer/sync-json-pluginnpx intlayer initFique a vontade para manter o
@nuxtjs/i18ninstalado e ativo seguramente ao longo de sua etapa de migração do código (estaremos desabilitando e varrendo o tal serviço brevemente na definição/configuração principal do Nuxt ali no passo adiante).Configure o Intlayer
O comando
intlayer initcria um arquivo inicialintlayer.config.ts. Atualize-o para corresponder aos seus locales existentes e direcione o pluginsyncJSONaos seus arquivos de mensagens:intlayer.config.tsCopiar códigoCopiar o código para a área de transferência
import { Locales, type IntlayerConfig } from "intlayer"; import { syncJSON } from "@intlayer/sync-json-plugin"; const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH, // Adicione todos os seus locales existentes aqui ], defaultLocale: Locales.ENGLISH, }, plugins: [ syncJSON({ // Corresponde à sintaxe de espaço reservado do vue-i18n: {name} format: "icu", source: ({ locale }) => `./locales/${locale}.json`, location: "locales", }), ], }; export default config;sourcemapeia um locale para o caminho do arquivo JSON correspondente.locationdiz ao observador (watcher) do Intlayer qual pasta monitorar para alterações. A opçãoformat: 'icu'garante que espaços reservados dovue-i18nsejam analisados corretamente.Atualize a Configuração do Nuxt
Troque a representação em tela que declarava antes como módulo o
@nuxtjs/i18npara em seguida adicionar no seunuxt.config.tso módulo atual sendonuxt-intlayer. Este plugin em si que pertence e constrói debaixo da base fornecida pelo sistema do Intlayer adiciona "em seus bastidores" injeções de reencaminhamentos automáticos via criação de aliases nos seus módulos com resultados que garantem e efetuam por onde ocorra declarações chamadas peloimport { useI18n } from 'vue-i18n'passem imperceptíveis e perfeitamente bem ao@intlayer/vue-i18n.nuxt.config.tsCopiar códigoCopiar o código para a área de transferência
export default defineNuxtConfig({ // Desapareça com o respectivo '@nuxtjs/i18n' modules: ["nuxt-intlayer"], });Acabou a necessidade para ter que embutir objetos do tipo i18n contendo formatações para o uso e controle do framework Nuxt Agora, por detrás de tudo e no próprio momento do build (build-time), é a inteligência do sistema principal do Intlayer que orquestra tudo englobando todos recursos relativos às identificações e mapeamentos por país, redirecionamentos a certas rotas bem como o gerenciamento do carregamento prévio que o material atrelado por trás embutirá.
Isso é tudo para a migração rápida. Seu aplicativo Nuxt agora está executando perfeitamente bem ao decorrer das chamadas que antes serviam em formato de $t somados também das chamadas via funcionalidade com nome igual a useI18n() a partir de dentro das suas próprias estruturas atadas no sistema operacional englobado e alimentado internamente a plataforma e ecossistema pelo uso contínuo de suporte atrelados as raízes de base Intlayer.
Migração Completa
As etapas a seguir são opcionais e podem ser feitas gradativamente. Elas desbloqueiam o conjunto completo das funcionalidades do Intlayer: editor visual, CMS, arquivos de conteúdo tipados, automação de tradução por IA e muito mais.
Renomeie Explícitamente as Importações (Opcional)
OpcionalO plugin atrelado à ferramenta Intlayer engloba nativamente a estrutura e lida com base no nível central da máquina empacotadora a parte relacionada a aliases no projeto. Ainda assim, caso seu interesse prefira forçar como explícitos os caminhos para uso nas suas fontes internas ou dependências diretas de origem nativa em particular, lhe daremos opções fáceis manuais voltadas para isso:
Mostrar todo o conteúdo da tabelaAbrir a tabela em um modal para ver todo o conteúdo claramente
Antes Depois import { useI18n } from 'vue-i18n'import { useI18n } from '@intlayer/vue-i18n'Essas são substituições diretas (drop-in) — nenhuma alteração de assinaturas de chamadas, argumentos ou tipos de retorno é necessária.
Habilite a Automação de Tradução por IA
OpcionalCom o Intlayer configurado, você pode usar a CLI para preencher traduções ausentes automaticamente:
bashCopiar códigoCopiar o código para a área de transferência
# Testar traduções ausentes (adicionar ao CI)npx intlayer test# Preencher traduções ausentes usando IAnpx intlayer fillAdicione a configuração de IA ao seu
intlayer.config.ts:intlayer.config.tsCopiar códigoCopiar o código para a área de transferência
import { Locales, type IntlayerConfig } from "intlayer"; import { syncJSON } from "@intlayer/sync-json-plugin"; const config: IntlayerConfig = { internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], defaultLocale: Locales.ENGLISH, }, plugins: [ syncJSON({ format: "icu", source: ({ locale }) => `./locales/${locale}.json`, location: "locales", }), ], ai: { apiKey: process.env.OPENAI_API_KEY, // provider: "openai", // padrão // model: "gpt-4o-mini", // padrão }, }; export default config;Verifique a Documentação da CLI do Intlayer para explorar todas as opções disponíveis.
O que pode ser excluído pós-migração
Uma vez que o adaptador de compatibilidade esteja implementado, o seguinte boilerplate padrão do @nuxtjs/i18n pode ser excluído:
Abrir a tabela em um modal para ver todo o conteúdo claramente
| Arquivo / Padrão | Por que não é mais necessário |
|---|---|
Objeto i18n contido no arquivo de inicialização de opções baseadas lá pelo nuxt.config.ts | É agora a máquina da Intlayer gerindo autonomamente as funcionalidades pertinentes aos caminhos do projeto, a rotina para invocar dados, bem como tudo que trata aos retornos do idioma principal sem que precise mais do auxílio direto de configurações avulsas vindas do @nuxtjs/i18n. |
Qualquer vestígio ligado e referenciado com menções visando resgatar pacotes pertencentes e listados na sua seção de importações do @nuxtjs/i18n presentes dentro da estrutura listada na montagem do objeto e do seu respectivo package.json | Desnecessário manter a dependência ao projeto visto as raízes profundas recém atadas junto da completa dependência que seu aplicativo criou de forma plena ao pacote pertencente ao nuxt-intlayer. |
Pacotes de idiomas JSON (locales/*.json) | Pacotes JSON são necessários apenas se você continuar a usar o plugin syncJSON. Uma vez migrado para arquivos .content.ts, você pode remover a pasta JSON. |
Quando você estiver pronto para ir mais além, o Intlayer descobre automaticamente todos os arquivos .content.ts e .content.json em qualquer lugar da sua base de código (por padrão, em qualquer lugar sob ./src). Basta colocar um arquivo my-component.content.ts ao lado do seu MyComponent.vue, e o Intlayer o detectará em tempo de build sem necessidade de configuração adicional — não são necessários imports, registros ou um arquivo index central. Isso torna a co-localização das traduções com páginas e componentes totalmente fluida.
Configuração do TypeScript
O Intlayer usa aumento de módulo (module augmentation) para fornecer IntelliSense completo no TypeScript (autocompletar) para as chaves de tradução. Certifique-se de que o seu arquivo tsconfig.json inclua os tipos gerados automaticamente:
Copiar o código para a área de transferência
{ // ... Suas configurações existentes de TypeScript "include": [ // ... Suas configurações existentes de TypeScript ".intlayer/**/*.ts", // Inclui os tipos gerados automaticamente ],}Configuração do Git
Adicione o diretório gerado pelo Intlayer ao seu .gitignore:
Copiar o código para a área de transferência
# Ignora arquivos gerados pelo Intlayer.intlayerExplore Além
- Editor Visual — Gerencie traduções visualmente no seu navegador: Editor Visual Intlayer
- CMS — Externalize o conteúdo e gerencie remotamente: CMS do Intlayer
- Extensão para VS Code — Obtenha autocompletar de tradução e detecção de erros em tempo real: Extensão do VS Code para o Intlayer
- Referência da CLI — Lista completa de comandos da CLI: CLI do Intlayer
- Intlayer com Nuxt — Guida completa de configuração para Nuxt: intlayerwithnuxt.md
- Intlayer com Vue — Guida completa de configuração para Vue: intlayerwithvite+vue.md