Автор:
    Создание:2026-06-22Последнее обновление:2026-06-22

    Интеграция с Preact: Документация хука usePathname

    Хук usePathname возвращает текущий путь (pathname) браузера с удалённым сегментом локали. Это полезно для создания навигации, учитывающей локаль — например, для определения активного элемента меню — без необходимости вручную удалять префикс локали.

    Импорт usePathname в Preact

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

    Обзор

    usePathname читает window.location.pathname, удаляет префикс локали с помощью getPathWithoutLocale и вызывает повторный рендеринг компонента каждый раз, когда браузер вызывает событие popstate (навигация назад/вперед). Во время серверного рендеринга (SSR) возвращает пустую строку.

    Использование

    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;

    Возвращаемое значение

    Тип Описание
    string Текущий путь без префикса локали. Во время серверного рендеринга (SSR) возвращается пустая строка.

    Поведение

    • Удаление локали (Locale stripping): Убирает начальный сегмент локали (например, /ru/dashboard/dashboard).
    • Реактивность: Автоматически обновляется при событиях popstate (навигация назад / вперед в браузере).
    • Безопасность для SSR: Возвращает "", если window недоступен.
    • Очистка (Cleanup): Слушатель popstate автоматически удаляется при размонтировании компонента.

    Пример

    src/components/Sidebar.tsx
    import type { FunctionComponent } from "preact";import { usePathname } from "preact-intlayer";const links = [  { href: "/dashboard", label: "Панель управления" },  { href: "/settings", label: "Настройки" },];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;

    Связанные материалы

    • useLocale — текущая локаль + переключатель локали
    • getPathWithoutLocale — базовая утилита, используемая этим хуком