Đặ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
Bằng cách tích hợp Intlayer MCP Server vào trợ lý AI ưa thích của bạn, bạn có thể truy xuất toàn bộ tài liệu trực tiếp từ ChatGPT, DeepSeek, Cursor, VSCode, v.v.
Xem tài liệu MCP ServerLịch sử phiên bản
- 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 React: Tài liệu Hook useDictionary
Phần này cung cấp hướng dẫn chi tiết về cách sử dụng hook useDictionary trong các ứng dụng React, cho phép xử lý hiệu quả nội dung đa ngôn ngữ mà không cần trình chỉnh sửa trực quan.
Nhập useDictionary trong React
Hook useDictionary có thể được tích hợp vào các ứng dụng React bằng cách nhập nó tùy theo ngữ cảnh:
Component phía Client:
import { useDictionary } from "react-intlayer"; // Sử dụng trong các component React phía clientComponent phía Server:
import { useDictionary } from "react-intlayer/server"; // Sử dụng trong các component React phía server
Tham số
Hook nhận hai tham số:
- dictionary: Một đối tượng từ điển đã được khai báo chứa nội dung được bản địa hóa cho các khóa cụ thể.
- locale (tùy chọn): Ngôn ngữ mong muốn. Mặc định là ngôn ngữ của ngữ cảnh hiện tại nếu không được chỉ định.
Từ điển
Tất cả các đối tượng từ điển nên được khai báo trong các tệp nội dung có cấu trúc để đảm bảo an toàn kiểu và ngăn ngừa lỗi trong thời gian chạy. Bạn có thể tìm thấy hướng dẫn thiết lập tại đây. Dưới đây là một ví dụ về khai báo nội dung:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { t, type Dictionary } from "intlayer";const componentContent = { key: "component-example", content: { title: t({ en: "Client Component Example", fr: "Exemple de composant client", es: "Ejemplo de componente cliente", }), content: t({ en: "This is the content of a client component example", fr: "Ceci est le contenu d'un exemple de composant client", es: "Este es el contenido de un ejemplo de componente cliente", }), },} satisfies Dictionary;export default componentContent;Ví dụ sử dụng trong React
Dưới đây là ví dụ về cách sử dụng hook useDictionary trong một component React:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import type { FC } from "react";import { useDictionary } from "react-intlayer";import componentContent from "./component.content";const ComponentExample: FC = () => { const { title, content } = useDictionary(componentContent); return ( <div> <h1>{title}</h1> <p>{content}</p> </div> );};Tích hợp Server
Nếu bạn sử dụng hook useDictionary bên ngoài IntlayerProvider, locale phải được cung cấp rõ ràng như một tham số khi render component:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import type { FC } from "react";import { useDictionary } from "react-intlayer/server";import clientComponentExampleContent from "./component.content";const ServerComponentExample: FC<{ locale: string }> = ({ locale }) => { const { content } = useDictionary(clientComponentExampleContent, locale); return ( <div> <h1>{content.title}</h1> <p>{content.content}</p> </div> );};Ghi chú về Thuộc tính
Không giống như các tích hợp sử dụng trình chỉnh sửa trực quan, các thuộc tính như buttonTitle.value không áp dụng ở đây. Thay vào đó, truy cập trực tiếp các chuỗi đã được địa phương hóa như đã khai báo trong nội dung của bạn.
<button title={content.title}>{content.content}</button>Mẹo bổ sung
- An toàn kiểu: Luôn sử dụng Dictionary để định nghĩa các từ điển của bạn nhằm đảm bảo an toàn kiểu.
- Cập nhật địa phương hóa: Khi cập nhật nội dung, hãy đảm bảo tất cả các ngôn ngữ đều nhất quán để tránh thiếu bản dịch.
Tài liệu này tập trung vào việc tích hợp hook useDictionary, cung cấp một phương pháp đơn giản để quản lý nội dung địa phương hóa mà không phụ thuộc vào các chức năng của trình chỉnh sửa trực quan.