首页演练场案例展示应用文档博客
    • English英语
      EN
    • русский俄语
      RU
    • 日本語日语
      JA
    • français法语
      FR
    • 한국어韩语
      KO
    • 中文中文
      ZH
    • español西班牙语
      ES
    • Deutsch德语
      DE
    • العربية阿拉伯语
      AR
    • italiano意大利语
      IT
    • British English英国英语
      EN-GB
    • português葡萄牙语
      PT
    • हिन्दी印地语
      HI
    • Türkçe土耳其语
      TR
    • polski波兰语
      PL
    • Indonesia印度尼西亚语
      ID
    • Tiếng Việt越南语
      VI
    • українська乌克兰语
      UK
    /
    按框架筛选文档
    Alt+←
    为什么Intlayer?
    开始
    概念
    • Intlayer如何工作
    • 配置
    • TestFillBuildWatchExtractLoginPushPullConfigurationListVersionEditorLiveDebugDoc ReviewDoc TranslateSDK
    • 可视化编辑器
    • CMS
    • CI/CD集成
    • 翻译复数枚举条件性别插入文件嵌套MarkdownHTML函数获取
    • 每个语言环境的文件
    • 编译器
    • 自动填充
    • 测试
    • 打包优化
    环境
    • Next.js 14和应用路由器
      Next.js 15
      Next.js 无 locale URL
      Next.js和页面路由器
      编译器
    • Tanstack Start Solid
    • Astro和React
      Astro和Svelte
      Astro和Vue
      Astro和Solid
      Astro和Preact
      Astro和Lit
      Astro和Vanilla JS
    • React Router v7
      React Router v7 (fs-routes)
      Compiler
    • Nuxt和Vue
    • Vite和Solid
    • SvelteKit
    • Vite和Preact
    • Vite和Vanilla JS
    • Vite和Lit
    • Angular 19 (Webpack)
      Analog
    • React CRA
    • React Native和Expo
    • Express.js
      NestJS
      Fastify
      Hono
      Adonis
    • Lynx和React
    Plugins
    • JSON
    • gettext (.po)
    VS Code扩展
    代理
    • MCP服务器
    • 代理技能
    发布
    • v8
    • v7
    • v6
    基准测试
    • Next.js
    • TanStack
    • Vue
    • Solid
    • Svelte
    博客
    问问题
    1. Documentation
    2. Packages
    3. Next intlayer
    4. UseLocale
    Creation:2024-08-11Last update:2026-01-26
    将此文档参考到您的 AI 助手
    ChatGPT
    Claude
    DeepSeek
    Google AI mode
    Gemini
    Perplexity
    Mistral
    Grok

    使用您最喜欢的AI助手总结文档,并引用此页面和AI提供商

    版本历史

    1. "将 `onLocaleChange` 默认值设置为 `replace`"
      v8.0.02026/1/26
    2. "初始化历史"
      v5.5.102025/6/29

    此页面的内容已使用 AI 翻译。

    查看英文原文的最新版本
    编辑此文档

    如果您有改善此文档的想法,请随时通过在GitHub上提交拉取请求来贡献。

    文档的 GitHub 链接
    Copy

    复制文档 Markdown 到剪贴板

    Next.js 集成:useLocale 钩子文档(适用于 next-intlayer)

    本节提供了针对 Next.js 应用中 next-intlayer 库的 useLocale 钩子的详细文档。该钩子旨在高效处理语言环境切换和路由。

    在 Next.js 中导入 useLocale

    要在 Next.js 应用中使用 useLocale 钩子,请按如下方式导入:

    javascript
    复制代码

    复制代码到剪贴板

    import { useLocale } from "next-intlayer"; // 用于管理 Next.js 中的语言环境和路由

    用法

    以下是在 Next.js 组件中实现 useLocale 钩子的方法:

    src/components/LocaleSwitcher.tsx
    复制代码

    复制代码到剪贴板

    "use client";
    
    import type { FC } from "react";
    import { Locales } from "intlayer";
    import { useLocale } from "next-intlayer";
    
    const LocaleSwitcher: FC = () => {
      const { locale, defaultLocale, availableLocales, setLocale } = useLocale();
    
      return (
        <div>
          <h1>当前语言环境: {locale}</h1>
          <p>默认语言环境: {defaultLocale}</p>
          <select value={locale} onChange={(e) => setLocale(e.target.value)}>
            {availableLocales.map((loc) => (
              <option key={loc} value={loc}>
                {loc}
              </option>
            ))}
          </select>
        </div>
      );
    };

    参数

    useLocale 钩子接受以下参数:

    • onLocaleChange:一个字符串,决定当语言环境改变时如何更新 URL。可以是 "replace"、"push" 或 "none"。

      让我们举个例子:

      1. 你当前在 /fr/home
      2. 你导航到 /fr/about
      3. 你将语言环境更改为 /es/about
      4. 你点击浏览器的“返回”按钮

      行为将根据 onLocaleChange 的值而有所不同:

      • "replace" (默认):用新的本地化 URL 替换当前 URL,并设置 cookie。 -> “返回”按钮将跳转到 /es/home
      • "push":将新的本地化 URL 添加到浏览器历史记录中,并设置 cookie。 -> “返回”按钮将跳转到 /fr/about
      • "none":仅在客户端上下文中更新语言环境,并设置 cookie,而不更改 URL。 -> “返回”按钮将跳转到 /fr/home
      • (locale) => void:设置 cookie 并触发语言环境更改时调用的自定义函数。

        undefined 选项是默认行为,因为我们建议使用 Link 组件导航到新的语言环境。 示例:

        tsx
        复制代码

        复制代码到剪贴板

        <Link href="/es/about" replace>  关于我们</Link>

    返回值

    • locale:当前在 React 上下文中设置的语言环境。
    • defaultLocale:配置中定义的主要语言环境。
    • availableLocales:配置中定义的所有可用语言环境列表。
    • setLocale:一个用于更改应用程序语言环境并相应更新 URL 的函数。它会处理前缀规则,根据配置决定是否将语言环境添加到路径中。利用 next/navigation 中的 useRouter 来执行导航功能,如 push 和 refresh。
    • pathWithoutLocale:一个计算属性,返回不包含语言环境的路径。它对于比较 URL 非常有用。例如,如果当前语言环境是 fr,且 URL 是 fr/my_path,则不含语言环境的路径为 /my_path。利用 next/navigation 中的 usePathname 获取当前路径。

    结论

    next-intlayer 的 useLocale 钩子是管理 Next.js 应用中多语言环境的关键工具。它通过无缝处理语言环境存储、状态管理和 URL 修改,提供了一种集成的方法来适配多语言应用。

    为什么Intlayer?
    Alt+→

    在此页面

      讨论是匿名的,并会定期审查以解决常见问题。欢迎分享功能想法、对文档的反馈或任何与 Intlayer 相关的内容, 我们会利用这些意见来制定路线图并改进产品。

      import { useLocale } from "next-intlayer"; // 用于管理 Next.js 中的语言环境和路由
      <Link href="/es/about" replace>  关于我们</Link>