Creation:2024-08-11Last update:2026-01-26
将此文档参考到您的 AI 助手ChatGPTClaudeDeepSeekGoogle AI modeGeminiPerplexityMistralGrok
使用您最喜欢的AI助手总结文档,并引用此页面和AI提供商
版本历史
- "将 `onLocaleChange` 默认值设置为 `replace`"v8.0.02026/1/26
- "初始化历史"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"。让我们举个例子:
- 你当前在
/fr/home - 你导航到
/fr/about - 你将语言环境更改为
/es/about - 你点击浏览器的“返回”按钮
行为将根据
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 修改,提供了一种集成的方法来适配多语言应用。