Đặ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
- "Tài liệu ban đầu"v7.1.016/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 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
Tài liệu: Hàm getPrefix trong intlayer
Mô tả
Hàm getPrefix xác định tiền tố URL cho một locale nhất định dựa trên cấu hình chế độ định tuyến. Nó so sánh locale với locale mặc định và trả về một đối tượng chứa ba định dạng tiền tố khác nhau để xây dựng URL linh hoạt.
Tính năng chính:
- Nhận một locale làm tham số đầu tiên (bắt buộc)
- Đối tượng
optionstùy chọn vớidefaultLocalevàmode - Trả về một đối tượng với các thuộc tính
prefixvàlocalePrefix - Hỗ trợ tất cả các chế độ định tuyến:
prefix-no-default,prefix-all,no-prefix, vàsearch-params - Công cụ nhẹ để xác định khi nào cần thêm tiền tố locale
Chữ ký hàm
Sao chép mã vào clipboard
getPrefix( locale: Locales, // Bắt buộc options?: { // Tùy chọn defaultLocale?: Locales; mode?: 'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'; }): GetPrefixResulttype GetPrefixResult = { prefix: string; // ví dụ: 'fr/' hoặc '' localePrefix?: Locale; // ví dụ: 'fr' hoặc undefined}Tham số
locale: Locales- Mô tả: Locale để tạo tiền tố. Nếu giá trị là falsy (undefined, null, chuỗi rỗng), hàm sẽ trả về chuỗi rỗng.
- Kiểu:
Locales - Bắt buộc: Có
options?: object- Mô tả: Đối tượng cấu hình để xác định tiền tố.
- Kiểu:
object Bắt buộc: Không (Tùy chọn)
options.defaultLocale?: Locales- Mô tả: Locale mặc định cho ứng dụng. Nếu không cung cấp, sẽ sử dụng locale mặc định được cấu hình trong cấu hình dự án của bạn.
- Kiểu:
Locales - Mặc định:
Cấu hình dự án
options.mode?: 'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params'- Mô tả: Chế độ định tuyến URL cho việc xử lý locale. Nếu không được cung cấp, sẽ sử dụng chế độ đã cấu hình trong cấu hình dự án của bạn.
- Kiểu:
'prefix-no-default' | 'prefix-all' | 'no-prefix' | 'search-params' - Mặc định:
Cấu hình dự án - Chế độ:
prefix-no-default: Trả về chuỗi rỗng khi locale trùng với locale mặc địnhprefix-all: Trả về tiền tố cho tất cả các locale bao gồm cả mặc địnhno-prefix: Trả về chuỗi rỗng (không có tiền tố trong URL)search-params: Trả về chuỗi rỗng (locale trong tham số truy vấn)
Trả về
- Kiểu:
GetPrefixResult - Mô tả: Một đối tượng chứa ba định dạng tiền tố khác nhau:
prefix: Tiền tố đường dẫn có dấu gạch chéo ở cuối (ví dụ:'fr/','')localePrefix: Định danh locale không có dấu gạch chéo (ví dụ:'fr',undefined)
Ví dụ sử dụng
Sử dụng cơ bản
Sao chép mã vào clipboard
import { getPrefix, Locales } from "intlayer";
// Kiểm tra tiền tố cho locale tiếng Anh
getPrefix(Locales.ENGLISH, {
defaultLocale: Locales.ENGLISH,
mode: "prefix-all",
});
// Trả về: { prefix: 'en/', localePrefix: 'en' }
// Kiểm tra tiền tố cho locale tiếng Pháp
getPrefix(Locales.FRENCH, {
defaultLocale: Locales.ENGLISH,
mode: "prefix-no-default",
});
// Trả về: { prefix: 'fr/', localePrefix: 'fr' }Các chế độ định tuyến khác nhau
Sao chép mã vào clipboard
import { getPrefix, Locales } from "intlayer";// prefix-all: Luôn trả về tiền tốgetPrefix(Locales.ENGLISH, { mode: "prefix-all", defaultLocale: Locales.ENGLISH,});// Trả về: { prefix: '/en', localePrefix: 'en' }// prefix-no-default: Không có tiền tố khi locale trùng với mặc địnhgetPrefix(Locales.ENGLISH, { mode: "prefix-no-default", defaultLocale: Locales.ENGLISH,});// Trả về: { prefix: '', localePrefix: undefined }// prefix-no-default: Trả về tiền tố khi locale khác với mặc địnhgetPrefix(Locales.FRENCH, { mode: "prefix-no-default", defaultLocale: Locales.ENGLISH,});// Trả về: { prefix: 'fr/', localePrefix: 'fr' }// no-prefix & search-params: Không bao giờ trả về tiền tốgetPrefix(Locales.ENGLISH, { mode: "no-prefix" });// Trả về: { prefix: '', localePrefix: undefined }getPrefix(Locales.ENGLISH, { mode: "search-params" });// Trả về: { prefix: '', localePrefix: undefined }Ví dụ Thực tế
Sao chép mã vào clipboard
import { getPrefix, Locales } from "intlayer";// Xây dựng URL với tiền tố phù hợp cho một locale cụ thểconst locale = Locales.FRENCH;const { prefix, localePrefix } = getPrefix(locale, { defaultLocale: Locales.ENGLISH, mode: "prefix-no-default",});// Sử dụng prefix để xây dựng đường dẫnconst url1 = `/${prefix}about`.replace(/\/+/g, "/");// Kết quả: "/fr/about"// Sử dụng localePrefix để nhận diện localeconsole.log(`Current locale: ${localePrefix}`);// Kết quả: "Current locale: fr"Các Hàm Liên Quan
getLocalizedUrl: Tạo URL có địa phương hóa cho một locale cụ thểgetMultilingualUrls: Tạo các URL cho tất cả các locale đã cấu hình
TypeScript
Sao chép mã vào clipboard
type GetPrefixResult = { prefix: string; // Tiền tố đường dẫn có dấu gạch chéo ở cuối (ví dụ: 'fr/' hoặc '') localePrefix?: Locale; // Định danh locale không có dấu gạch chéo (ví dụ: 'fr' hoặc undefined)};function getPrefix( locale: Locales, options?: { defaultLocale?: Locales; mode?: "prefix-no-default" | "prefix-all" | "no-prefix" | "search-params"; }): GetPrefixResult;