Đặ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
- "Khởi tạo lịch sử"v8.0.426/1/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 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
Dịch ứng dụng Analog (Angular) của bạn bằng Intlayer | Quốc tế hóa (i18n)
Mục lục
Intlayer là gì?
Intlayer là một thư viện quốc tế hóa (i18n) nguồn mở sáng tạo được thiết kế để đơn giản hóa việc hỗ trợ đa ngôn ngữ trong các ứng dụng web hiện đại.
Với Intlayer, bạn có thể:
- Dễ dàng quản lý các bản dịch bằng cách sử dụng các từ điển khai báo ở cấp độ thành phần.
- Bản địa hóa động các siêu dữ liệu, các tuyến đường và nội dung.
- Đảm bảo hỗ trợ TypeScript với các kiểu dữ liệu được tự động tạo, cải thiện khả năng tự động hoàn thành và phát hiện lỗi.
- Hưởng lợi từ các tính năng nâng cao, như phát hiện và chuyển đổi ngôn ngữ động.
Hướng dẫn từng bước để thiết lập Intlayer trong ứng dụng Analog
Xem Mẫu ứng dụng trên GitHub.
Bước 1: Cài đặt các phụ thuộc
Cài đặt các gói cần thiết bằng npm:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
npm install intlayer angular-intlayer vite-intlayernpx 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 mã và các lệnh CLI.
angular-intlayer Gói tích hợp Intlayer với ứng dụng Angular. Nó cung cấp các trình cung cấp ngữ cảnh (context providers) và các hook cho quốc tế hóa Angular.
vite-intlayer Gói tích hợp Intlayer với Vite. Nó cung cấp một plugin để xử lý các tệp khai báo nội dung và thiết lập các bí danh (aliases) để đạt hiệu suất tối ưu.
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 đoạn mã vào khay nhớ tạm (clipboard)
import { Locales, type IntlayerConfig } from "intlayer";
const config: IntlayerConfig = {
internationalization: {
locales: [
Locales.ENGLISH,
Locales.FRENCH,
Locales.SPANISH,
// Các ngôn ngữ khác của bạn
],
defaultLocale: Locales.ENGLISH,
},
};
export default config;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 trung gian (middleware redirection), tên cookie, vị trí và phần mở rộng của các khai báo nội dung của bạn, tắt nhật ký Intlayer trong bảng điều khiển, và nhiều hơn nữa. Để 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 vào cấu hình Vite của bạn
Để tích hợp Intlayer với Analog, bạn cần sử dụng plugin vite-intlayer.
Sửa đổi tệp vite.config.ts của bạn:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { defineConfig } from "vite";import { intlayer } from "vite-intlayer";import analog from "@analogjs/platform";// https://vitejs.dev/config/export default defineConfig(() => ({ plugins: [ analog(), intlayer(), // Thêm plugin Intlayer ],}));Plugin intlayer() cấu hình Vite với Intlayer. Nó xử lý các tệp khai báo nội dung và thiết lập các bí danh để đạt hiệu suất tối ưu.
Bước 4: Khai báo nội dung của bạn
Tạo và quản lý các khai báo nội dung của bạn để lưu trữ các bản dịch:
Các khai báo nội dung của bạn có thể được định nghĩa ở bất kỳ đâu trong ứng dụng của bạn miễn là chúng được bao gồm trong thư mụccontentDir(mặc định là./src). Và khớp với phần mở rộng tệp khai báo nội dung (mặc định là.content.{json,ts,tsx,js,jsx,mjs,cjs}).
Để biết thêm chi tiết, hãy tham khảo tài liệu khai báo nội dung.
Bước 5: Sử dụng Intlayer trong mã của bạn
Để sử dụng các tính năng quốc tế hóa của Intlayer trong suốt ứng dụng Analog của bạn, bạn cần cung cấp Intlayer trong cấu hình ứng dụng của mình.
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { ApplicationConfig } from "@angular/core";import { provideIntlayer } from "angular-intlayer";export const appConfig: ApplicationConfig = { providers: [ provideIntlayer(), // Thêm trình cung cấp Intlayer tại đây ],};Sau đó, bạn có thể sử dụng hàm useIntlayer trong bất kỳ thành phần nào.
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { Component } from "@angular/core";import { useIntlayer } from "angular-intlayer";@Component({ selector: "app-home", standalone: true, template: ` <div class="content"> <h1>{{ content().title }}</h1> <p>{{ content().congratulations }}</p> </div> `,})export default class HomeComponent { content = useIntlayer("app");}Nội dung Intlayer được trả về dưới dạng một Signal, vì vậy bạn truy cập các giá trị bằng cách gọi signal: content().title.
(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 hàm useLocale. Điều 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.
Tạo một thành phần để chuyển đổi giữa các ngôn ngữ:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { Component } from "@angular/core";import { CommonModule } from "@angular/common";import { useLocale } from "angular-intlayer";@Component({ selector: "app-locale-switcher", standalone: true, imports: [CommonModule], template: ` <div class="locale-switcher"> <select [value]="locale()" (change)="setLocale($any($event.target).value)" > @for (loc of availableLocales; track loc) { <option [value]="loc">{{ loc }}</option> } </select> </div> `,})export class LocaleSwitcherComponent { localeCtx = useLocale(); locale = this.localeCtx.locale; availableLocales = this.localeCtx.availableLocales; setLocale = this.localeCtx.setLocale;}Sau đó, sử dụng thành phần này trong các trang của bạn:
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
import { Component } from "@angular/core";import { useIntlayer } from "angular-intlayer";import { LocaleSwitcherComponent } from "../locale-switcher.component";@Component({ selector: "app-home", standalone: true, imports: [LocaleSwitcherComponent], template: ` <app-locale-switcher></app-locale-switcher> <div class="content"> <h1>{{ content().title }}</h1> <p>{{ content().congratulations }}</p> </div> `,})export default class HomeComponent { content = useIntlayer("app");}Cấu hình TypeScript
Intlayer sử dụng module augmentation để tận dụng các lợi ích của TypeScript và làm cho mã nguồn của bạn mạnh mẽ hơn.


Đảm bảo cấu hình TypeScript của bạn bao gồm các kiểu dữ liệu được tự động tạo.
Sao chép đoạn mã vào khay nhớ tạm (clipboard)
{ // ... Các cấu hình TypeScript hiện tại của bạn "include": [ // ... Các cấu hình TypeScript hiện tại của bạn ".intlayer/**/*.ts", // Bao gồm các kiểu dữ liệu được tự động tạo ],}Cấu hình Git
Khuyên dùng bỏ qua các tệp được tạo bởi Intlayer. Điều này cho phép bạn tránh việc commit chúng vào kho lưu trữ Git của mình.
Để thực hiện việc 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 đoạn mã vào khay nhớ tạm (clipboard)
# Bỏ qua các tệp được tạo bởi Intlayer.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 Tiện ích mở rộng Intlayer VS Code chính thức.
Cài đặt từ VS Code Marketplace
Tiện ích mở rộng này cung cấp:
- Tự động hoàn thành cho các khóa dịch.
- Phát hiện lỗi thời gian thực cho các bản dịch bị thiếu.
- Xem trước nội tuyến nội dung đã dịch.
- Các hành động nhanh để dễ dàng tạo và cập nhật các bản dịch.
Để biết thêm chi tiết về cách sử dụng tiện ích mở rộng, hãy tham khảo tài liệu Tiện ích mở rộng Intlayer VS Code.