Sorunuzu sorun ve bu sayfaya ve seçtiğiniz AI sağlayıcısına referans vererek belgenin bir özetini alın
Bu sayfanın içeriği bir yapay zeka kullanılarak çevrildi.
Orijinal içeriğin İngilizce son sürümünü görüntüleyinBu dokümantasyonu geliştirmek için bir fikriniz varsa, lütfen GitHub'da bir çekme isteği göndererek katkıda bulunmaktan çekinmeyin.
Dokümantasyon için GitHub bağlantısıBelge Markdown'ını panoya kopyala
Yeni Intlayer v9 - Yenilikler Neler?
Intlayer v9'a hoş geldiniz! Bu ana sürüm, büyük i18n kütüphaneleri (react-i18next, next-intl, vue-i18n vb.) için sunulan Compat Adapter Paketleri ile Intlayer'a geçiş sürecini basitleştirmede dev bir adımı temsil ediyor ve zengin içerik yapıları için destek ekliyor: Koleksiyonlar (Collections), Varyantlar (Variants) ve Dinamik Kayıtlar (Dynamic Records).
İçindekiler
Compat Adapter Paketleri
Popüler i18n kütüphanelerinden Intlayer'a geçiş yapmak artık her zamankinden daha kolay. Standart i18n kütüphaneleriyle birebir aynı genel API'leri (public APIs) sunan ancak çalışma zamanında (runtime) tüm çeviri işlerini Intlayer'a devreden beş adet uyumluluk (compat) paketi oluşturduk.
Sıkı Tiplendirme ile Aynı Genel API'yi Sunma
İçe aktarmaları (imports) değiştirerek, minimum kod değişikliğiyle Intlayer'ın tüm avantajlarından (gerçek sözlüklerinize karşı derleme zamanı tip güvenliği dahil) yararlanabilirsiniz:
@intlayer/i18next@intlayer/react-i18next@intlayer/next-intl@intlayer/next-i18next@intlayer/vue-i18n
Örneğin, sadece şunu değiştirin:
Kodu panoya kopyala
şuna:
Kodu panoya kopyala
Anahtarlarınız artık Intlayer sözlüklerinize karşı sıkı bir şekilde tiplendirilecek (strictly typed) ve IDE'nizde tam nokta yolu (dot-path) otomatik tamamlama desteği sunacak!
Bundler Alias Eklentileri (Vite, Next.js, Turbopack)
Tüm içe aktarma ifadelerinizi manuel olarak yeniden yazmadan geçiş yapabilmenizi sağlamak için, her compat adapter paketi /plugin alt yolu altında özel bir bundler eklentisi (Vite veya Next.js) içerir.
Bu eklentiler, derleme zamanında (build time) mevcut içe aktarmaları (örneğin react-i18next veya next-intl) otomatik olarak @intlayer/* eşdeğerlerine dönüştürür.
Next.js (Webpack / Turbopack) Örneği
withIntlayer yerine, Next.js yapılandırmanızı compat eklentisi ile sarmalayın:
Kodu panoya kopyala
Vite (React, Vue, Solid, Svelte) Örneği
Kodu panoya kopyala
Ortaklaştırılmış Çalışma Zamanı Çözümleyicisi (Mutualized Runtime Resolver)
Tüm compat adapter'lar artık çeviri çözümlemesini tek ve son derece optimize edilmiş bir çalışma zamanı ayrıştırıcısı (runtime parser) üzerinden yönlendiriyor: @intlayer/core/messageFormat.
- Mesaj Değişkeni Ekleme (Interpolate Message): Standart
{{var}}(boşluklar ve nokta yolları), ICU biçimlendirilmiş argümanlar ({v, number, percent}vb.) ve yalın{var}şablonlarını çözümler. - Mesaj Düğümü Çözümleyici (Message Node Resolver): İç içe geçmiş düğümleri çözümler:
insert(),plural()(CLDR çoğul kuralları),enu()(numaralandırma),gender(), HTML etiketleri, diziler ve çağrılabilir fonksiyon düğümleri. - Tokenized Tag Parser: Zengin metin (rich-text) oluşturmayı kutudan çıktığı gibi desteklemek için satır içi XML/HTML etiketlerini ve numaralandırılmış etiketleri (örneğin,
<1>children</1>) destekler.
Özellik Detayları: Koleksiyonlar, Varyantlar ve Dinamik Kayıtlar
Intlayer v9, statik anahtar-değer nesnelerinin ötesine geçerek sözlüklerin uçtan uca tam tiplendirilmiş dinamik düzen yapıları tanımlamasına olanak tanır.
1. Koleksiyonlar (Collections)
CMS tarafından yönetilen sıralı öğelerin bir listesini tanımlayın (örneğin SSS'ler, ürünler veya blog listeleri):
Kodu panoya kopyala
Kullanım:
Kodu panoya kopyala
2. Varyantlar (Variants)
A/B testleri, mevsimsel başlıklar, özellik bayrakları (feature flags) veya özel açılış sayfaları sunun:
Kodu panoya kopyala
Kullanım:
Kodu panoya kopyala
3. Dinamik Kayıtlar (Dynamic Records)
Girdileri çalışma zamanında sorgu kimlikleri (query IDs) aracılığıyla dinamik olarak yüklenen sözlükler tanımlayın:
Kodu panoya kopyala
Kullanım:
Kodu panoya kopyala
Dinamik Yükleme ve Bundle Boyutu Optimizasyonları
Bundle boyutlarını son derece küçük tutmak için Intlayer v9 dinamik tembel yüklemeyi (dynamic lazy loading) destekler.
Yapılandırmanızda importMode değerini 'dynamic' veya 'fetch' olarak ayarlayın:
Kodu panoya kopyala
Derleme zamanında, @intlayer/swc ve @intlayer/babel dosyalarınızı tarar ve useIntlayer / getIntlayer çağrılarını tree-shakeable sarmalayıcılarla (useDictionary / useDictionaryDynamic) değiştirir. Yalnızca seçilen koleksiyon öğesi, varyant veya dil (locale) için gerekli olan içerik yüklenir, böylece üretim (production) bundle'ınızın kullanılmayan çevirileri içermesi engellenir.
v8'den Geçiş Notları
v8'den yükseltme yapıyorsanız, v9'un yıkıcı değişiklikler (breaking changes) içermediğini unutmayın. Ancak işte temel değişiklikler:
- Diller ve Lehçeler (Locales & Dialects): Harici i18n bağımlılıkları kullanıyorsanız, içe aktarmaları otomatik olarak yeniden yazmak için yapılandırmanıza veya bundler kurulumunuza ilgili compat adapter eklentilerini ekleyin.
- Özel Seçiciler (Custom Selectors):
useIntlayerçağrılırken, ikinci parametre artık{ locale, item, variant, id }içeren bir seçenek nesnesine ayrılmıştır. Daha önce doğrudan bir dil (locale) dizesi geçirdiyseniz bunu yapmaya devam edebilirsiniz, ancak gelişmiş seçimler için seçenekler nesnesini kullanmanız önerilir.