Đặt câu hỏi và nhận tóm tắt tài liệu bằng cách tham chiếu trang này và nhà cung cấp AI bạn chọn
Lịch sử phiên bản
- "Mặc định `onLocaleChange` thành `replace`"v8.0.026/1/2026
- "Thêm tài liệu cho hook `useLocale` với tùy chọn `onLocaleChange`"v6.2.09/10/2025
- "Khởi tạo lịch sử"v5.5.1029/6/2025
Nội dung của trang này đã được dịch bằng AI.
Xem phiên bản mới nhất của nội dung gốc bằng tiếng AnhNếu bạn có ý tưởng để cải thiện tài liệu này, vui lòng đóng góp bằng cách gửi pull request trên GitHub.
Liên kết GitHub tới tài liệuSao chép Markdown của tài liệu vào bộ nhớ tạm
Tích hợp Next.js: Tài liệu Hook useLocale cho next-intlayer
Phần này cung cấp tài liệu chi tiết về hook useLocale được thiết kế riêng cho các ứng dụng Next.js trong thư viện next-intlayer. Hook này được tạo ra để xử lý thay đổi ngôn ngữ và điều hướng một cách hiệu quả.
Nhập useLocale trong Next.js
Để sử dụng hook useLocale trong ứng dụng Next.js của bạn, hãy nhập nó như sau:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { useLocale } from "next-intlayer"; // Dùng để quản lý ngôn ngữ và điều hướng trong Next.jsCách sử dụng
Dưới đây là cách triển khai hook useLocale trong một component Next.js:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
"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>Ngôn ngữ hiện tại: {locale}</h1>
<p>Ngôn ngữ mặc định: {defaultLocale}</p>
<select value={locale} onChange={(e) => setLocale(e.target.value)}>
{availableLocales.map((loc) => (
<option key={loc} value={loc}>
{loc}
</option>
))}
</select>
</div>
);
};Tham số
Hook useLocale chấp nhận các tham số sau:
onLocaleChange: Một chuỗi xác định cách URL sẽ được cập nhật khi ngôn ngữ thay đổi. Nó có thể là"replace","push"hoặc"none".Hãy lấy ví dụ:
- Bạn đang ở
/fr/home - Bạn điều hướng đến
/fr/about - Bạn chuyển sang
/es/about - Bạn nhấn nút "quay lại" của trình duyệt
Hành vi sẽ khác nhau dựa trên giá trị của
onLocaleChange:"replace"(mặc định): Thay thế URL hiện tại bằng URL đã được địa phương hóa mới, và đặt cookie. -> Nút "quay lại" sẽ dẫn đến/es/home"push": Thêm URL đã được địa phương hóa mới vào lịch sử trình duyệt, và đặt cookie. -> Nút "quay lại" sẽ dẫn đến/fr/about"none": Chỉ cập nhật ngôn ngữ trong ngữ cảnh client, và đặt cookie, mà không thay đổi URL. -> Nút "quay lại" sẽ dẫn đến/fr/home(locale) => void: Đặt cookie và kích hoạt một hàm tùy chỉnh sẽ được gọi khi ngôn ngữ thay đổi.Tùy chọn
undefinedlà hành vi mặc định vì chúng tôi khuyến nghị sử dụng componentLinkđể điều hướng đến ngôn ngữ mới. Ví dụ:tsxSao chép mãSao chép đoạn mã vào khay nhớ tạm (clipboard)
<Link href="/es/about" replace> About</Link>
- Bạn đang ở
Giá trị trả về
Khi bạn gọi hook useLocale, nó trả về một đối tượng chứa các thuộc tính sau:
locale: Ngôn ngữ hiện tại được thiết lập trong React context.defaultLocale: Ngôn ngữ chính được định nghĩa trong cấu hình.availableLocales: Danh sách tất cả các ngôn ngữ có sẵn theo cấu hình.setLocale: Một hàm để thay đổi ngôn ngữ của ứng dụng và cập nhật URL tương ứng. Hàm này xử lý các quy tắc tiền tố, quyết định có thêm ngôn ngữ vào đường dẫn hay không dựa trên cấu hình. Sử dụnguseRoutertừnext/navigationcho các chức năng điều hướng nhưpushvàrefresh.pathWithoutLocale: Một thuộc tính được tính toán trả về đường dẫn không có ngôn ngữ. Thuộc tính này hữu ích để so sánh các URL. Ví dụ, nếu ngôn ngữ hiện tại làfr, và URL làfr/my_path, thì đường dẫn không có ngôn ngữ là/my_path. Sử dụngusePathnametừnext/navigationđể lấy đường dẫn hiện tại.
Kết luận
Hook useLocale từ next-intlayer là một công cụ quan trọng để quản lý ngôn ngữ trong các ứng dụng Next.js. Nó cung cấp một phương pháp tích hợp để điều chỉnh ứng dụng của bạn cho nhiều ngôn ngữ bằng cách xử lý lưu trữ ngôn ngữ, quản lý trạng thái và sửa đổi URL một cách liền mạch.