Autor:
    Criação:2026-06-22Última atualização:2026-06-22

    Integração Preact: Documentação do Hook usePathname

    O hook usePathname retorna o pathname (caminho) atual do navegador com o segmento da locale removido. Isso é útil para construir uma navegação ciente da locale — por exemplo, determinar qual item de navegação está ativo — sem precisar remover manualmente o prefixo da locale.

    Importando usePathname no Preact

    typescript
    import { usePathname } from "preact-intlayer";

    Visão Geral

    usePathnamewindow.location.pathname, remove o prefixo da locale por meio da função getPathWithoutLocale e re-renderiza o componente sempre que o navegador acionar o evento popstate (navegação de voltar/avançar). Ele retorna uma string vazia durante a renderização no lado do servidor (SSR).

    Uso

    src/components/NavItem.tsx
    import type { FunctionComponent } from "preact";import { usePathname } from "preact-intlayer";type NavItemProps = {  href: string;  label: string;};const NavItem: FunctionComponent<NavItemProps> = ({ href, label }) => {  const pathname = usePathname();  const isActive = pathname === href;  return (    <a href={href} aria-current={isActive ? "page" : undefined}>      {label}    </a>  );};export default NavItem;

    Valor de Retorno

    Tipo Descrição
    string O pathname atual sem o prefixo da locale. String vazia durante a renderização no lado do servidor (SSR).

    Comportamento

    • Remoção da Locale (Locale stripping): Remove o segmento inicial correspondente à locale (ex: /pt/dashboard/dashboard).
    • Reativo: Atualiza automaticamente em eventos popstate (navegação de voltar / avançar do navegador).
    • Seguro para SSR: Retorna "" quando window não está disponível.
    • Limpeza (Cleanup): O listener do popstate é removido automaticamente quando o componente é desmontado.

    Exemplo

    src/components/Sidebar.tsx
    import type { FunctionComponent } from "preact";import { usePathname } from "preact-intlayer";const links = [  { href: "/dashboard", label: "Dashboard" },  { href: "/settings", label: "Configurações" },];const Sidebar: FunctionComponent = () => {  const pathname = usePathname();  return (    <nav>      {links.map(({ href, label }) => (        <a          key={href}          href={href}          style={{ fontWeight: pathname === href ? "bold" : "normal" }}        >          {label}        </a>      ))}    </nav>  );};export default Sidebar;

    Relacionados