Ajukan pertanyaan Anda dan dapatkan ringkasan dokumen dengan merujuk halaman ini dan penyedia AI pilihan Anda
Riwayat Versi
- "Inisialisasi riwayat"v5.5.1029/6/2025
Konten halaman ini diterjemahkan menggunakan AI.
Lihat versi terakhir dari konten aslinya dalam bahasa InggrisJika Anda memiliki ide untuk meningkatkan dokumentasi ini, silakan berkontribusi dengan mengajukan pull request di GitHub.
Tautan GitHub ke dokumentasiSalin Markdown dokumentasi ke clipboard
Dokumentasi: Fungsi t di express-intlayer
Fungsi t dalam paket express-intlayer adalah utilitas inti untuk menyediakan respons yang dilokalisasi dalam aplikasi Express Anda. Fungsi ini mempermudah internasionalisasi (i18n) dengan memilih konten secara dinamis berdasarkan bahasa yang dipilih pengguna.
Ikhtisar
Fungsi t digunakan untuk mendefinisikan dan mengambil terjemahan untuk satu set bahasa tertentu. Fungsi ini secara otomatis menentukan bahasa yang tepat untuk dikembalikan berdasarkan pengaturan permintaan klien, seperti header Accept-Language. Jika bahasa yang dipilih tidak tersedia, fungsi ini dengan mulus akan kembali ke locale default yang ditentukan dalam konfigurasi Anda.
Fitur Utama
- Lokalisasi Dinamis: Secara otomatis memilih terjemahan yang paling sesuai untuk klien.
- Fallback ke Locale Default: Kembali ke locale default jika bahasa pilihan klien tidak tersedia, memastikan kelangsungan pengalaman pengguna.
- Ringan dan Cepat: Dirancang untuk aplikasi dengan performa tinggi, memastikan overhead minimal.
- Dukungan Mode Ketat: Menerapkan kepatuhan ketat pada locale yang dideklarasikan untuk perilaku yang dapat diandalkan.
Tanda Tangan Fungsi
Parameter
translations: Sebuah objek di mana kunci adalah kode locale (misalnya,en,fr,es-MX) dan nilainya adalah string terjemahan yang sesuai.
Mengembalikan
- Sebuah string yang mewakili konten dalam bahasa pilihan klien.
Memuat Handler Permintaan Internasionalisasi
Untuk memastikan bahwa fungsi internasionalisasi yang disediakan oleh express-intlayer bekerja dengan benar, Anda harus memuat middleware internasionalisasi di awal aplikasi Express Anda. Ini memungkinkan fungsi t dan memastikan penanganan yang tepat untuk deteksi locale dan terjemahan.
Tempatkan middleware app.use(intlayer()) sebelum rute apa pun dalam aplikasi Anda untuk memastikan bahwa semua rute mendapatkan manfaat dari internasionalisasi:
Mengapa Ini Diperlukan
- Deteksi Locale: Middleware
intlayermemproses permintaan yang masuk untuk mendeteksi locale yang dipilih pengguna berdasarkan header, cookie, atau metode lain yang dikonfigurasi. - Konteks Terjemahan: Menyiapkan konteks yang diperlukan agar fungsi
tdapat beroperasi dengan benar, memastikan terjemahan dikembalikan dalam bahasa yang tepat. - Pencegahan Error: Tanpa middleware ini, penggunaan fungsi
takan menyebabkan error saat runtime karena informasi locale yang diperlukan tidak tersedia.
Contoh Penggunaan
Contoh Dasar
Melayani konten yang dilokalkan dalam berbagai bahasa:
Permintaan Klien:
- Klien dengan
Accept-Language: frakan menerimaBienvenue!. - Klien dengan
Accept-Language: esakan menerima¡Bienvenido!. - Klien dengan
Accept-Language: deakan menerimaWelcome!(locale default).
Menangani Error
Berikan pesan error dalam berbagai bahasa:
Menggunakan Varian Locale
Tentukan terjemahan untuk varian spesifik locale:
Topik Lanjutan
Mekanisme Fallback
Jika locale yang diinginkan tidak tersedia, fungsi t akan kembali menggunakan locale default yang didefinisikan dalam konfigurasi:
Sebagai contoh:
- Jika
defaultLocaleadalahLocales.CHINESEdan klien memintaLocales.DUTCH, terjemahan yang dikembalikan akan menggunakan nilaiLocales.CHINESEsecara default. - Jika
defaultLocaletidak didefinisikan, fungsitakan kembali menggunakan nilaiLocales.ENGLISH.
Penegakan Mode Ketat
Konfigurasikan fungsi t untuk menegakkan kepatuhan ketat terhadap locale yang dideklarasikan:
Buka tabel dalam modal untuk melihat semua isi data dengan jelas
| Mode | Perilaku |
|---|---|
strict | Semua locale yang dideklarasikan harus memiliki terjemahan. Locale yang hilang akan menyebabkan error. |
inclusive | Locale yang dideklarasikan harus memiliki terjemahan. Locale yang hilang akan memicu peringatan tetapi diterima. |
loose | Locale yang ada diterima, bahkan jika tidak dideklarasikan. |
Contoh Konfigurasi:
Integrasi TypeScript
Fungsi t aman tipe saat digunakan dengan TypeScript. Definisikan objek terjemahan yang aman tipe:
Kesalahan Umum dan Pemecahan Masalah
Buka tabel dalam modal untuk melihat semua isi data dengan jelas
| Masalah | Penyebab | Solusi |
|---|---|---|
Fungsi t tidak berfungsi | Middleware tidak dimuat | Pastikan app.use(intlayer()) ditambahkan sebelum routes. |
| Kesalahan terjemahan hilang | Mode ketat diaktifkan tanpa semua locale | Sediakan semua terjemahan yang diperlukan. |
Tips untuk Penggunaan Efektif
- Sentralisasi Terjemahan: Gunakan modul terpusat atau file JSON untuk mengelola terjemahan agar memudahkan pemeliharaan.
- Validasi Terjemahan: Pastikan setiap varian bahasa memiliki terjemahan yang sesuai untuk mencegah fallback yang tidak perlu.
- Gabungkan dengan i18n Frontend: Sinkronkan dengan internasionalisasi frontend untuk pengalaman pengguna yang mulus di seluruh aplikasi.
- Uji Kinerja: Uji waktu respons aplikasi Anda saat menambahkan terjemahan untuk memastikan dampak minimal.
Kesimpulan
Fungsi t adalah alat yang kuat untuk internasionalisasi backend. Dengan menggunakannya secara efektif, Anda dapat membuat aplikasi yang lebih inklusif dan ramah pengguna untuk audiens global. Untuk penggunaan lanjutan dan opsi konfigurasi yang lebih rinci, lihat dokumentasi.