Receba notificações sobre os próximos lançamentos de Intlayer
    Criação:2024-08-11Última atualização:2025-06-29

    Integração com React: Documentação do Hook useI18n

    Esta seção fornece orientações detalhadas sobre como usar o hook useI18n em aplicações React, permitindo uma localização eficiente de conteúdo.

    Importando useI18n no React

    O hook useI18n pode ser importado e integrado em aplicações React conforme o contexto, da seguinte forma:

    • Componentes Cliente:

      typescript
      import { useI18n } from "react-intlayer"; // Use em componentes React do lado do cliente
    • Componentes Servidor:

    Parâmetros

    Este hook aceita dois parâmetros:

    1. namespace: Um namespace de dicionário para delimitar as chaves de tradução.
    2. locale (opcional): O locale desejado. Se não especificado, o locale do contexto será usado como padrão.

    Dicionário

    Todas as chaves do dicionário devem ser declaradas dentro dos arquivos de declaração de conteúdo para aumentar a segurança de tipos e evitar erros. Instruções de configuração podem ser encontradas aqui.

    Exemplos de Uso em React

    Exemplos de uso do hook useI18n dentro de componentes React:

    src/App.tsx
    import type { FC } from "react";import { ClientComponentExample, ServerComponentExample } from "@components";import { IntlayerProvider } from "react-intlayer";import { useI18n, IntlayerServerProvider } from "react-intlayer/server";import { Locales } from "intlayer";const App: FC<{ locale: Locales }> = ({ locale }) => {  const t = useI18n("home-page", locale);  return (    <>      <p>{t("introduction")}</p>      <IntlayerProvider locale={locale}>        <ClientComponentExample />      </IntlayerProvider>      <IntlayerServerProvider locale={locale}>        <ServerComponentExample />      </IntlayerServerProvider>    </>  );};
    src/components/ComponentExample.tsx
    import type { FC } from "react";import { useI18n } from "react-intlayer";const ComponentExample: FC = () => {  const t = useI18n("component-example");  return (    <div>      <h1>{t("title")}</h1> {/* Exibe o título */}      <p>{t("description")}</p> {/* Exibe a descrição */}    </div>  );};
    src/components/ServerComponentExample.tsx
    import { useI18n } from "react-intlayer/server";const ServerComponentExample = () => {  const t = useI18n("server-component");  return (    <div>      <h1>{t("title")}</h1> {/* Exibe o título */}      <p>{t("description")}</p> {/* Exibe a descrição */}    </div>  );};

    Manipulação de Atributos

    Ao localizar atributos, acesse os valores de tradução de forma apropriada:

    jsx
    <!-- Para atributos de acessibilidade (ex.: aria-label), use .value pois são necessárias strings puras --><button aria-label={t("button.ariaLabel").value}>{t("button.text")}</button>

    Recursos Adicionais

    • Editor Visual Intlayer: Para uma experiência de gerenciamento de conteúdo mais intuitiva, consulte a documentação do editor visual aqui.

    Esta seção cobre especificamente a integração do hook useI18n em aplicações React, simplificando o processo de localização e garantindo a consistência do conteúdo entre diferentes locais.

    Histórico da Documentação

    • 6.0.0 - 2025-06-29: Escrita inicial da documentação do hook useI18n
    Receba notificações sobre os próximos lançamentos de Intlayer