Đặ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
- "Cập nhật cách sử dụng API useIntlayer của Solid sang truy cập thuộc tính trực tiếp"v8.9.04/5/2026
- "Update compiler options, add FilePathPattern support"v8.2.09/3/2026
- "Phát hành lần đầu"v8.1.623/2/2026
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 AnhIf you have an idea for improving this documentation, please feel free to contribute by submitting a pull request on GitHub.
GitHub link to the documentationCopy doc Markdown to clipboard
Cách làm cho ứng dụng Vite và React hiện có trở thành đa ngôn ngữ (i18n) sau đó (hướng dẫn i18n 2026)
Xem Mẫu ứng dụng trên GitHub.
Mục lục
Tại sao việc quốc tế hóa một ứng dụng hiện có lại khó khăn?
Nếu bạn đã từng thử thêm nhiều ngôn ngữ vào một ứng dụng vốn chỉ được xây dựng cho một ngôn ngữ, bạn sẽ hiểu được nỗi vất vả đó. Nó không chỉ "khó" mà còn cực kỳ tẻ nhạt. Bạn phải rà soát qua từng tệp tin, săn lùng từng chuỗi văn bản và chuyển chúng vào các tệp từ điển riêng biệt.
Sau đó là phần đầy rủi ro: thay thế toàn bộ văn bản đó bằng các hook mã nguồn mà không làm hỏng giao diện hoặc logic của bạn. Đó là loại công việc khiến việc phát triển tính năng mới bị đình trệ trong nhiều tuần và cảm giác như một quá trình cấu trúc lại mã (refactoring) không bao giờ kết thúc.
Intlayer Compiler là gì?
Intlayer Compiler được xây dựng để bỏ qua những công việc thủ công nặng nhọc đó. Thay vì bạn phải tự trích xuất các chuỗi ký tự, trình biên dịch sẽ làm việc đó cho bạn. Nó quét mã của bạn, tìm văn bản và sử dụng AI để tạo ra các từ điển ở chế độ nền. Sau đó, nó sửa đổi mã của bạn trong quá trình xây dựng (build) để chèn các hook i18n cần thiết. Về cơ bản, bạn vẫn viết ứng dụng như thể nó chỉ có một ngôn ngữ, và trình biên dịch sẽ tự động xử lý việc chuyển đổi đa ngôn ngữ.
Tài liệu trình biên dịch: /vi/doc/compiler
Hạn chế
Vì trình biên dịch thực hiện phân tích và chuyển đổi mã (chèn hook và tạo từ điển) tại thời điểm biên dịch, nó có thể làm chậm quá trình xây dựng ứng dụng của bạn.
Để giảm bớt tác động này trong quá trình phát triển, bạn có thể cấu hình trình biên dịch chạy ở chế độ 'build-only' hoặc tắt nó khi không cần thiết.
Hướng dẫn từng bước để thiết lập Intlayer trong ứng dụng Vite và React
Bước 1: Cài đặt các gói phụ thuộc
Cài đặt các gói cần thiết bằng npm:
Sao chép mã vào clipboard
npm install intlayer react-intlayernpm install vite-intlayer --save-devnpx intlayer initintlayer Gói cốt lõi cung cấp các công cụ quốc tế hóa để quản lý cấu hình, dịch thuật, khai báo nội dung, chuyển đổi mã và các lệnh CLI.
react-intlayer Gói tích hợp Intlayer với ứng dụng React. Nó cung cấp các trình cung cấp ngữ cảnh (context providers) và các hook cho việc quốc tế hóa React.
vite-intlayer Bao gồm plugin Vite để tích hợp Intlayer với Vite bundler, cũng như middleware để phát hiện ngôn ngữ ưa thích của người dùng, quản lý cookie và xử lý chuyển hướng URL.
Bước 2: Cấu hình dự án của bạn
Tạo một tệp cấu hình để thiết lập các ngôn ngữ cho ứng dụng của bạn:
Sao chép mã vào clipboard
import { Locales, type IntlayerConfig } from "intlayer";const config: IntlayerConfig = { internationalization: { locales: [Locales.ENGLISH, Locales.VIETNAMESE, Locales.FRENCH], defaultLocale: Locales.ENGLISH, }, compiler: { /** * Cho biết trình biên dịch có nên được bật hay không. */ enabled: true, /** * Thư mục đầu ra cho các từ điển được tối ưu hóa. */ output: ({ locale, key }) => `compiler/${locale}/${key}.json`, /** * Chỉ chèn nội dung vào tệp đã tạo, không có khóa. */ noMetadata: false, /** * Tiền tố khóa từ điển */ dictionaryKeyPrefix: "", // Remove base prefix /** * Cho biết liệu các thành phần có nên được lưu sau khi được chuyển đổi hay không. * Bằng cách đó, trình biên dịch có thể được chạy một lần duy nhất để chuyển đổi ứng dụng, và sau đó nó có thể được gỡ bỏ. */ saveComponents: false, }, ai: { provider: "openai", model: "gpt-5-mini", apiKey: process.env.OPEN_AI_API_KEY, applicationContext: "Ứng dụng này là một ứng dụng bản đồ", // Lưu ý: bạn có thể tùy chỉnh mô tả ứng dụng này },};export default config;Lưu ý: Đảm bảo bạn đã đặt OPEN_AI_API_KEY trong các biến môi trường của mình.
Thông qua tệp cấu hình này, bạn có thể thiết lập các URL được bản địa hóa, chuyển hướng middleware, tên cookie, vị trí và phần mở rộng của các khai báo nội dung, tắt nhật ký Intlayer trong console, v.v. Để biết danh sách đầy đủ các tham số có sẵn, hãy tham khảo tài liệu cấu hình.
Bước 3: Tích hợp Intlayer trong cấu hình Vite của bạn
Thêm plugin intlayer vào cấu hình của bạn.
Sao chép mã vào clipboard
import { defineConfig } from "vite";import react from "@vitejs/plugin-react-swc";import { intlayer, intlayerCompiler } from "vite-intlayer";// https://vitejs.dev/config/export default defineConfig({ plugins: [react(), intlayer(), intlayerCompiler()],});Plugin Vite intlayer() được sử dụng để tích hợp Intlayer với Vite. Nó đảm bảo việc xây dựng các tệp khai báo nội dung và theo dõi chúng trong chế độ phát triển. Nó định nghĩa các biến môi trường Intlayer trong ứng dụng Vite. Ngoài ra, nó cung cấp các bí danh (aliases) để tối ưu hóa hiệu suất.
Plugin ViteintlayerCompiler()được sử dụng để trích xuất nội dung từ component và ghi các tệp.content.
Bước 4: Biên dịch mã của bạn
Chỉ cần viết các component của bạn với các chuỗi ký tự được mã hóa cứng (hardcoded) bằng ngôn ngữ mặc định của bạn. Trình biên dịch sẽ xử lý phần còn lại.
Ví dụ về giao diện trang của bạn có thể trông như sau:
Sao chép mã vào clipboard
import { useState, type FC } from "react";import reactLogo from "./assets/react.svg";import viteLogo from "/vite.svg";import "./App.css";import { IntlayerProvider } from "react-intlayer";const AppContent: FC = () => { const [count, setCount] = useState(0); return ( <> <div> <a href="https://vitejs.dev" target="_blank"> <img src={viteLogo} className="logo" alt="Vite logo" /> </a> <a href="https://react.dev" target="_blank"> <img src={reactLogo} className="logo react" alt="React logo" /> </a> </div> <h1>Vite + React</h1> <div className="card"> <button onClick={() => setCount((count) => count + 1)}> count is {count} </button> <p> Edit <code>src/App.tsx</code> and save to test HMR </p> </div> <p className="read-the-docs"> Click on the Vite and React logos to learn more </p> </> );};const App: FC = () => ( <IntlayerProvider> <AppContent /> </IntlayerProvider>);export default App;IntlayerProviderđược sử dụng để cung cấp ngôn ngữ cho các component con.
(Tùy chọn) Bước 6: Thay đổi ngôn ngữ của nội dung
Để thay đổi ngôn ngữ của nội dung, bạn có thể sử dụng hàm setLocale được cung cấp bởi hook useLocale. Hàm này cho phép bạn thiết lập ngôn ngữ của ứng dụng và cập nhật nội dung tương ứng.
Sao chép mã vào clipboard
import type { FC } from "react";import { Locales } from "intlayer";import { useLocale } from "react-intlayer";const LocaleSwitcher: FC = () => { const { setLocale } = useLocale(); return ( <button onClick={() => setLocale(Locales.English)}> Thay đổi ngôn ngữ sang tiếng Anh </button> );};Để tìm hiểu thêm về hook useLocale, hãy tham khảo tài liệu.
(Tùy chọn) Bước 7: Điền các bản dịch còn thiếu
Intlayer cung cấp một công cụ CLI để giúp bạn điền các bản dịch còn thiếu. Bạn có thể sử dụng lệnh intlayer để kiểm tra và điền các bản dịch còn thiếu từ mã nguồn của bạn.
Sao chép mã vào clipboard
npx intlayer test # Kiểm tra xem có bản dịch nào còn thiếu khôngSao chép mã vào clipboard
npx intlayer fill # Điền các bản dịch còn thiếuĐể biết thêm chi tiết, vui lòng tham khảo tài liệu CLI
(Tuỳ chọn) Sitemap và robots.txt (sinh lúc build)
Intlayer cung cấp generateSitemap và getMultilingualUrls để định dạng sitemap.xml đa ngôn ngữ và robots.txt cho crawler rồi tự ghi vào public/. Thường chạy một script Node nhỏ trước Vite (ví dụ hook npm predev / prebuild).
Sitemap
Trình tạo sitemap của Intlayer tôn trọng cấu hình locale và thêm metadata cho crawler.
Sitemap hỗ trợ không gian tênxhtml:link(hreflang). Thay vì chỉ liệt kê URL phẳng, Intlayer nối hai chiều mọi bản địa phương của từng trang (ví dụ/about,/fr/abouthoặc/about?lang=frtùy chế độ routing).
Robots.txt
Dùng getMultilingualUrls để quy tắc Disallow áp dụng cho mọi biến thể URL của đường dẫn nhạy cảm.
1. Thêm generate-seo.mjs ở thư mục gốc dự án
Sao chép mã vào clipboard
import fs from "fs";import path from "path";import { fileURLToPath } from "url";import { generateSitemap, getMultilingualUrls } from "intlayer";const __dirname = path.dirname(fileURLToPath(import.meta.url));const SITE_URL = (process.env.SITE_URL || "http://localhost:5173").replace( /\/$/, "");const pathList = [ { path: "/", changefreq: "daily", priority: 1.0 }, { path: "/about", changefreq: "monthly", priority: 0.7 },];const sitemapXml = generateSitemap(pathList, { siteUrl: SITE_URL });fs.writeFileSync(path.join(__dirname, "public", "sitemap.xml"), sitemapXml);const getAllMultilingualUrls = (urls) => urls.flatMap((url) => Object.values(getMultilingualUrls(url)));const disallowedPaths = getAllMultilingualUrls(["/admin", "/private"]);const robotsTxt = [ "User-agent: *", "Allow: /", ...disallowedPaths.map((path) => `Disallow: ${path}`), "", `Sitemap: ${SITE_URL}/sitemap.xml`,].join("\n");fs.writeFileSync(path.join(__dirname, "public", "robots.txt"), robotsTxt);console.log("SEO files generated successfully.");Cần cài intlayer để script import. Môi trường production đặt SITE_URL (ví dụ trong CI).
Nên dùnggenerate-seo.mjscho ESM của Node. Nếu dùnggenerate-seo.js, đặt"type": "module"trongpackage.jsonhoặc bật ESM tương đương.
2. Chạy script trước Vite
Sao chép mã vào clipboard
{ "scripts": { "dev": "vite", "prebuild": "node generate-seo.mjs", "build": "vite build", "preview": "vite preview" }}Chỉnh lệnh nếu dùng pnpm hoặc yarn. Có thể gọi từ CI hoặc bước pipeline khác.
Cấu hình Git
Khuyên dùng bỏ qua các tệp do Intlayer tạo ra. Điều này giúp bạn tránh việc commit chúng vào kho lưu trữ Git của mình.
Để làm điều này, bạn có thể thêm các hướng dẫn sau vào tệp .gitignore của mình:
Sao chép mã vào clipboard
# Bỏ qua các tệp do Intlayer tạo ra.intlayerTiện ích mở rộng VS Code
Để cải thiện trải nghiệm phát triển của bạn với Intlayer, bạn có thể cài đặt Intlayer VS Code Extension chính thức.
Cài đặt từ VS Code Marketplace
Tiện ích này cung cấp:
- Tự động hoàn thành cho các khóa dịch thuật.
- Phát hiện lỗi thời gian thực cho các bản dịch còn thiếu.
- Xem trước trực tiếp nội dung đã dịch.
- Các hành động nhanh để dễ dàng tạo và cập nhật bản dịch.
Để biết thêm chi tiết về cách sử dụng tiện ích, hãy tham khảo tài liệu Intlayer VS Code Extension.
Đi xa hơn
Để tìm hiểu sâu hơn, bạn có thể triển khai visual editor hoặc bên thứ ba hóa nội dung của bạn bằng CMS.