Đặ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
- Phát hành Trình Biên Dịchv7.3.127/11/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
Trình Biên Dịch Intlayer | Trích Xuất Nội Dung Tự Động cho i18n
Trình Biên Dịch Intlayer là gì?
Trình Biên Dịch Intlayer là một công cụ mạnh mẽ được thiết kế để tự động hóa quy trình quốc tế hóa (i18n) trong các ứng dụng của bạn. Nó quét mã nguồn của bạn (JSX, TSX, Vue, Svelte) để tìm các khai báo nội dung, trích xuất chúng và tự động tạo ra các tệp từ điển cần thiết. Điều này cho phép bạn giữ nội dung cùng vị trí với các component của mình trong khi Intlayer xử lý việc quản lý và đồng bộ hóa các từ điển đó.
Tại sao nên sử dụng Trình Biên Dịch Intlayer?
- Tự động hóa: Loại bỏ việc sao chép thủ công nội dung vào từ điển.
- Tốc độ: Tối ưu hóa việc trích xuất nội dung đảm bảo quá trình build của bạn vẫn nhanh.
- Trải nghiệm nhà phát triển: Giữ các khai báo nội dung ngay tại nơi chúng được sử dụng, cải thiện khả năng bảo trì.
- Cập nhật trực tiếp: Hỗ trợ Hot Module Replacement (HMR) để phản hồi ngay lập tức trong quá trình phát triển.
Xem bài viết blog Compiler vs. Declarative i18n để có sự so sánh sâu hơn.
Tại sao không sử dụng Trình Biên Dịch Intlayer?
Mặc dù trình biên dịch mang lại trải nghiệm "hoạt động ngay" tuyệt vời, nó cũng giới thiệu một số đánh đổi mà bạn nên biết:
- Sự mơ hồ của heuristic: Trình biên dịch phải đoán xem đâu là nội dung hướng đến người dùng so với logic ứng dụng (ví dụ: className="active", mã trạng thái, ID sản phẩm). Trong các codebase phức tạp, điều này có thể dẫn đến dương tính giả hoặc các chuỗi bị bỏ sót cần chú thích thủ công và ngoại lệ.
- Chỉ trích xuất tĩnh: Trích xuất dựa trên trình biên dịch dựa vào phân tích tĩnh. Các chuỗi chỉ tồn tại ở thời gian chạy (mã lỗi API, trường CMS, v.v.) không thể được phát hiện hoặc dịch bởi trình biên dịch một mình, vì vậy bạn vẫn cần một chiến lược i18n thời gian chạy bổ sung.
Để có so sánh kiến trúc sâu hơn, xem bài viết blog Compiler vs. Declarative i18n.
Như một giải pháp thay thế, để tự động hóa quy trình i18n của bạn trong khi vẫn giữ quyền kiểm soát hoàn toàn đối với nội dung của bạn, Intlayer cũng cung cấp lệnh tự động trích xuất intlayer transform (xem tài liệu CLI), hoặc lệnh Intlayer: extract content to Dictionary từ tiện ích mở rộng Intlayer VS Code (xem tài liệu tiện ích mở rộng VS Code).
Cách sử dụng
Vite
Đối với các ứng dụng dựa trên Vite (React, Vue, Svelte, v.v.), cách dễ nhất để sử dụng trình biên dịch là thông qua plugin vite-intlayer.
Cài đặt
npm install vite-intlayerCấu hình
Cập nhật file vite.config.ts của bạn để bao gồm plugin intlayerCompiler:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { defineConfig } from "vite";import { intlayer, intlayerCompiler } from "vite-intlayer";export default defineConfig({ plugins: [ intlayer(), intlayerCompiler(), // Thêm plugin trình biên dịch ],});Hỗ trợ Framework
Plugin Vite tự động phát hiện và xử lý các loại file khác nhau:
- React / JSX / TSX: Xử lý một cách tự nhiên.
- Vue: Yêu cầu @intlayer/vue-compiler.
- Svelte: Yêu cầu @intlayer/svelte-compiler.
Hãy chắc chắn cài đặt gói trình biên dịch phù hợp với framework của bạn:
# Dành cho Vuenpm install @intlayer/vue-compiler# Dành cho Sveltenpm install @intlayer/svelte-compilerNext.js (Babel)
Đối với Next.js hoặc các ứng dụng dựa trên Webpack sử dụng Babel, bạn có thể cấu hình trình biên dịch bằng cách sử dụng plugin @intlayer/babel.
Cài đặt
npm install @intlayer/babelCấu hình
Cập nhật babel.config.js (hoặc babel.config.json) của bạn để bao gồm plugin trích xuất. Chúng tôi cung cấp một helper getExtractPluginOptions để tự động tải cấu hình Intlayer của bạn.
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
const { intlayerExtractBabelPlugin, intlayerOptimizeBabelPlugin, getExtractPluginOptions, getOptimizePluginOptions,} = require("@intlayer/babel");module.exports = { presets: ["next/babel"], plugins: [ // Extract content from components into dictionaries [intlayerExtractBabelPlugin, getExtractPluginOptions()], // Optimize imports by replacing useIntlayer with direct dictionary imports [intlayerOptimizeBabelPlugin, getOptimizePluginOptions()], ],};Cấu hình này đảm bảo rằng nội dung được khai báo trong các component của bạn sẽ được tự động trích xuất và sử dụng để tạo từ điển trong quá trình build.