Đặ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
- Thêm tài liệu đồng bộ trực tiếpv6.0.122/9/2025
- Thay thế trường `hotReload` bằng `liveSync`v6.0.04/9/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ài liệu Hệ thống Quản lý Nội dung (CMS) Intlayer
Intlayer CMS là một ứng dụng cho phép bạn đưa nội dung của dự án Intlayer ra ngoài.
Để làm được điều đó, Intlayer giới thiệu khái niệm 'từ điển từ xa'.

Mục lục
Hiểu về từ điển từ xa
Intlayer phân biệt giữa 'từ điển cục bộ' và 'từ điển từ xa'.
'Từ điển cục bộ' là từ điển được khai báo trong dự án Intlayer của bạn. Ví dụ như file khai báo của một nút bấm, hoặc thanh điều hướng của bạn. Việc đưa nội dung ra ngoài không có ý nghĩa trong trường hợp này vì nội dung này không được dự kiến thay đổi thường xuyên.
'Từ điển từ xa' là từ điển được quản lý thông qua Intlayer CMS. Điều này có thể hữu ích để cho phép nhóm của bạn quản lý nội dung trực tiếp trên trang web của bạn, đồng thời nhằm sử dụng các tính năng thử nghiệm A/B và tối ưu hóa SEO tự động.
Trình chỉnh sửa trực quan và CMS
Trình chỉnh sửa Intlayer Visual là một công cụ cho phép bạn quản lý nội dung trong trình chỉnh sửa trực quan dành cho các từ điển cục bộ. Khi có sự thay đổi, nội dung sẽ được thay thế trong code-base. Điều này có nghĩa là ứng dụng sẽ được xây dựng lại và trang sẽ được tải lại để hiển thị nội dung mới.
Ngược lại, Intlayer CMS là một công cụ cho phép bạn quản lý nội dung trong trình chỉnh sửa trực quan dành cho các từ điển từ xa. Khi có sự thay đổi, nội dung sẽ không ảnh hưởng đến code-base của bạn. Và trang web sẽ tự động hiển thị nội dung đã thay đổi.
Tích hợp
Để biết thêm chi tiết về cách cài đặt gói, xem phần liên quan bên dưới:
Tích hợp với Next.js
Để tích hợp với Next.js, tham khảo hướng dẫn cài đặt.
Tích hợp với Create React App
Để tích hợp với Create React App, tham khảo hướng dẫn cài đặt.
Tích hợp với Vite + React
Để tích hợp với Vite + React, tham khảo hướng dẫn cài đặt.
Cấu hình
Trong file cấu hình Intlayer của bạn, bạn có thể tùy chỉnh các thiết lập CMS:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import type { IntlayerConfig } from "intlayer";const config: IntlayerConfig = { // ... các thiết lập cấu hình khác editor: { /** * Bắt buộc * * URL của ứng dụng. * Đây là URL mà trình chỉnh sửa trực quan sẽ hướng tới. */ applicationURL: process.env.INTLAYER_APPLICATION_URL, /** * Bắt buộc * * Client ID và client secret là bắt buộc để kích hoạt trình chỉnh sửa. * Chúng cho phép xác định người dùng đang chỉnh sửa nội dung. * Có thể lấy được bằng cách tạo một client mới trong Bảng điều khiển Intlayer - Projects (https://intlayer.org/dashboard/projects). * clientId: process.env.INTLAYER_CLIENT_ID, * clientSecret: process.env.INTLAYER_CLIENT_SECRET, */ clientId: process.env.INTLAYER_CLIENT_ID, clientSecret: process.env.INTLAYER_CLIENT_SECRET, /** * Tùy chọn * * Trong trường hợp bạn tự lưu trữ Intlayer CMS, bạn có thể thiết lập URL của CMS. * * URL của Intlayer CMS. * Mặc định, nó được đặt là https://intlayer.org */ cmsURL: process.env.INTLAYER_CMS_URL, /** * Tùy chọn * * Trong trường hợp bạn tự lưu trữ Intlayer CMS, bạn có thể thiết lập URL của backend. * * URL của Intlayer CMS. * Mặc định, nó được đặt là https://back.intlayer.org */ backendURL: process.env.INTLAYER_BACKEND_URL, },};export default config;Nếu bạn chưa có client ID và client secret, bạn có thể lấy chúng bằng cách tạo một client mới trong Intlayer Dashboard - Projects.
Để xem tất cả các tham số có sẵn, hãy tham khảo tài liệu cấu hình.
Sử dụng CMS
Đẩy cấu hình của bạn
Để cấu hình Intlayer CMS, bạn có thể sử dụng các lệnh của intlayer CLI.
npx intlayer config pushNếu bạn sử dụng biến môi trường trong tệp cấu hình intlayer.config.ts, bạn có thể chỉ định môi trường mong muốn bằng cách sử dụng đối số --env:
npx intlayer config push --env productionLệnh này sẽ tải cấu hình của bạn lên Intlayer CMS.
Đẩy một từ điển
Để chuyển đổi các từ điển locale của bạn thành một từ điển từ xa, bạn có thể sử dụng các lệnh của intlayer CLI.
npx intlayer dictionary push -d my-first-dictionary-keyNếu bạn sử dụng biến môi trường trong tệp cấu hình intlayer.config.ts, bạn có thể chỉ định môi trường mong muốn bằng cách sử dụng đối số --env:
npx intlayer dictionary push -d my-first-dictionary-key --env productionLệnh này sẽ tải các từ điển nội dung ban đầu của bạn lên, giúp chúng có thể được lấy và chỉnh sửa bất đồng bộ thông qua nền tảng Intlayer.
Chỉnh sửa từ điển
Sau đó, bạn sẽ có thể xem và quản lý từ điển của mình trong Intlayer CMS.
Đồng bộ trực tiếp (Live sync)
Live Sync cho phép ứng dụng của bạn phản ánh các thay đổi nội dung CMS trong thời gian chạy. Không cần xây dựng lại hoặc triển khai lại. Khi được bật, các cập nhật sẽ được truyền đến máy chủ Live Sync để làm mới các từ điển mà ứng dụng của bạn đang đọc.
Bật Live Sync bằng cách cập nhật cấu hình Intlayer của bạn:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import type { IntlayerConfig } from "intlayer";const config: IntlayerConfig = { // ... các thiết lập cấu hình khác editor: { /** * Bật tính năng tải lại nóng (hot reloading) cấu hình locale khi phát hiện thay đổi. * Ví dụ, khi một từ điển được thêm hoặc cập nhật, ứng dụng sẽ cập nhật * nội dung hiển thị trên trang. * * Vì tải lại nóng yêu cầu kết nối liên tục với máy chủ, * tính năng này chỉ có sẵn cho khách hàng của gói `enterprise`. * * Mặc định: false */ liveSync: true, }, build: { /** * Điều khiển cách các từ điển được nhập khẩu: * * - "live": Các từ điển được lấy động bằng cách sử dụng Live Sync API. * Thay thế useIntlayer bằng useDictionaryDynamic. * * Lưu ý: Chế độ live sử dụng Live Sync API để lấy từ điển. Nếu cuộc gọi API * thất bại, các từ điển sẽ được nhập khẩu động. * Lưu ý: Chỉ các từ điển có nội dung từ xa và cờ "live" mới sử dụng chế độ live. * Các từ điển khác sử dụng chế độ động để tối ưu hiệu năng. */ importMode: "live", },};export default config;Khởi động server Live Sync để bao bọc ứng dụng của bạn:
Ví dụ sử dụng server độc lập:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
{ "scripts": { // ... các script khác "live:start": "npx intlayer live", },}Bạn cũng có thể sử dụng server ứng dụng của mình song song bằng cách sử dụng đối số --process.
Ví dụ sử dụng Next.js:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
{ "scripts": { // ... các script khác "build": "next build", "dev": "next dev", "start": "npx intlayer live --process 'next start'", },}Ví dụ sử dụng Vite:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
{ "scripts": { // ... các script khác "build": "vite build", "dev": "vite dev", "start": "npx intlayer live --process 'vite start'", },}Server Live Sync bao bọc ứng dụng của bạn và tự động áp dụng nội dung cập nhật khi nó đến.
Để nhận thông báo thay đổi từ CMS, server Live Sync duy trì một kết nối SSE đến backend. Khi nội dung thay đổi trong CMS, backend chuyển tiếp bản cập nhật đến server Live Sync, server này sẽ ghi các từ điển mới. Ứng dụng của bạn sẽ phản ánh bản cập nhật trong lần điều hướng tiếp theo hoặc khi tải lại trình duyệt — không cần phải xây dựng lại.
Sơ đồ luồng (CMS/Backend -> Live Sync Server -> Application Server -> Frontend):
Cách hoạt động:
Quy trình phát triển (cục bộ)
- Trong quá trình phát triển, tất cả các từ điển từ xa được lấy khi ứng dụng khởi động, giúp bạn có thể kiểm tra các cập nhật nhanh chóng.
- Để thử nghiệm Live Sync cục bộ với Next.js, hãy bao bọc server phát triển của bạn:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
{ "scripts": { // ... các script khác "dev": "npx intlayer live --process 'next dev'", // "dev": "npx intlayer live --process 'vite dev'", // Dành cho Vite },}Bật tối ưu hóa để Intlayer áp dụng các biến đổi nhập khẩu Live trong quá trình phát triển:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import type { IntlayerConfig } from "intlayer";const config: IntlayerConfig = { editor: { applicationURL: "http://localhost:5173", liveSyncURL: "http://localhost:4000", liveSync: true, }, build: { optimize: true, // mặc định: process.env.NODE_ENV === 'production' importMode: "live", },};export default config;Cấu hình này bao bọc server phát triển của bạn với server Live Sync, lấy các từ điển từ xa khi khởi động, và truyền các cập nhật từ CMS qua SSE. Tải lại trang để xem các thay đổi.
Ghi chú và hạn chế:
- Thêm nguồn gốc live sync vào chính sách bảo mật trang web của bạn (CSP). Đảm bảo URL live sync được phép trong connect-src (và frame-ancestors nếu có liên quan).
- Live Sync không hoạt động với đầu ra tĩnh. Đối với Next.js, trang phải là động để nhận các cập nhật tại thời gian chạy (ví dụ: sử dụng generateStaticParams, generateMetadata, getServerSideProps, hoặc getStaticProps một cách phù hợp để tránh các hạn chế chỉ tĩnh hoàn toàn).
- Trong CMS, mỗi từ điển có một cờ live. Chỉ những từ điển có live=true mới được lấy qua API live sync; những từ điển khác được nhập động và không thay đổi trong thời gian chạy.
- Cờ live được đánh giá cho mỗi từ điển tại thời điểm build. Nếu nội dung từ xa không được đánh dấu live=true trong quá trình build, bạn phải build lại để kích hoạt Live Sync cho từ điển đó.
- Server live sync phải có quyền ghi vào .intlayer. Trong các container, đảm bảo quyền ghi vào /.intlayer.
Gỡ lỗi
Nếu bạn gặp bất kỳ vấn đề nào với CMS, hãy kiểm tra các điều sau:
Ứng dụng đang chạy.
Cấu hình editor được thiết lập chính xác trong file cấu hình Intlayer của bạn.
- Các trường bắt buộc:
- URL ứng dụng phải khớp với URL bạn đã thiết lập trong cấu hình editor (applicationURL).
- URL CMS
- Các trường bắt buộc:
Đảm bảo rằng cấu hình dự án đã được đẩy lên Intlayer CMS.
Trình chỉnh sửa trực quan sử dụng iframe để hiển thị trang web của bạn. Đảm bảo rằng Chính sách Bảo mật Nội dung (CSP) của trang web cho phép URL CMS làm frame-ancestors (mặc định là 'https://intlayer.org'). Kiểm tra bảng điều khiển của editor để phát hiện lỗi.