Sorunuzu sorun ve bu sayfaya ve seçtiğiniz AI sağlayıcısına referans vererek belgenin bir özetini alın
Sürüm Geçmişi
- "Derleyici seçeneklerini güncelle, FilePathPattern desteği ekle"v8.2.009.03.2026
- "Derleyici seçeneklerini güncelle"v8.1.725.02.2026
- "Compiler Yayınlandı"v7.3.127.11.2025
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
Intlayer Compiler | i18n için Otomatik İçerik Çıkarımı
Intlayer Compiler Nedir?
Intlayer Compiler, uygulamalarınızda uluslararasılaştırma (i18n) sürecini otomatikleştirmek için tasarlanmış güçlü bir araçtır. Kaynak kodunuzu (JSX, TSX, Vue, Svelte) içerik bildirimleri için tarar, bunları çıkarır ve gerekli sözlük dosyalarını otomatik olarak oluşturur. Bu sayede içeriğinizi bileşenlerinizle birlikte tutabilirken, Intlayer sözlüklerinizin yönetimi ve senkronizasyonunu üstlenir.
Neden Intlayer Compiler Kullanmalısınız?
- Otomasyon: İçeriğin sözlüklere manuel olarak kopyalanıp yapıştırılmasını ortadan kaldırır.
- Hız: Derleme sürecinizin hızlı kalmasını sağlayan optimize edilmiş içerik çıkarımı.
- Geliştirici Deneyimi: İçerik bildirimlerini kullanıldıkları yerde tutarak bakım kolaylığı sağlar.
- Canlı Güncellemeler: Geliştirme sırasında anlık geri bildirim için Hot Module Replacement (HMR) desteği sağlar.
Daha derin bir karşılaştırma için Compiler vs. Declarative i18n blog yazısına bakabilirsiniz.
Neden Intlayer Compiler Kullanmamalısınız?
Derleyici mükemmel bir "hemen çalışır" deneyimi sunarken, aynı zamanda farkında olmanız gereken bazı ödünleşmeler de getirir:
- Sezgisel belirsizlik: Derleyici, kullanıcıya yönelik içerik ile uygulama mantığı arasındaki farkı tahmin etmek zorundadır (örneğin,
className="active", durum kodları, ürün kimlikleri). Karmaşık kod tabanlarında, bu manuel açıklamalar ve istisnalar gerektiren yanlış pozitifler veya kaçırılan dizelerle sonuçlanabilir. - Yalnızca statik çıkarım: Derleyici tabanlı çıkarım statik analize dayanır. Yalnızca çalışma zamanında var olan dizeler (API hata kodları, CMS alanları vb.) derleyici tarafından tek başına keşfedilemez veya çevrilemez, bu nedenle hala tamamlayıcı bir çalışma zamanı i18n stratejisine ihtiyacınız vardır.
Daha derin bir mimari karşılaştırma için Compiler vs. Declarative i18n blog yazısına bakın.
Alternatif olarak, içeriğiniz üzerinde tam kontrolü korurken i18n sürecinizi otomatikleştirmek için, Intlayer ayrıca otomatik çıkarım komutu intlayer extract (bkz. CLI dokümantasyonu) veya Intlayer VS Code uzantısının Intlayer: extract content to Dictionary komutunu (bkz. VS Code uzantı dokümantasyonu) sağlar.
Kullanım
Vite
Vite tabanlı uygulamalar (React, Vue, Svelte, vb.) için derleyiciyi kullanmanın en kolay yolu vite-intlayer eklentisidir.
Kurulum
Kodu panoya kopyala
npm install vite-intlayerKonfigürasyon
vite.config.ts dosyanızı intlayerCompiler eklentisini içerecek şekilde güncelleyin:
Kodu panoya kopyala
import { defineConfig } from "vite";import { intlayer, intlayerCompiler } from "vite-intlayer";export default defineConfig({ plugins: [ intlayer(), intlayerCompiler(), // Derleyici eklentisini ekler ],});See complete tutorial: Intlayer Compiler with Vite+React
Framework Desteği
Vite eklentisi farklı dosya türlerini otomatik olarak algılar ve işler:
- React / JSX / TSX: Yerel olarak desteklenir.
- Vue:
@intlayer/vue-compilergerektirir. - Svelte:
@intlayer/svelte-compilergerektirir.
Framework'ünüz için uygun derleyici paketini kurduğunuzdan emin olun:
Kodu panoya kopyala
# Vue içinnpm install @intlayer/vue-compiler# Svelte içinnpm install @intlayer/svelte-compilerÖzel yapılandırma
Derleyici davranışını özelleştirmek için projenizin kök dizinindeki intlayer.config.ts dosyasını güncelleyebilirsiniz.
Kodu panoya kopyala
import { type IntlayerConfig, Locales } from "intlayer";const config: IntlayerConfig = { compiler: { /** * Derleyicinin etkinleştirilip etkinleştirilmeyeceğini belirtir. * Geliştirme sırasında derleyiciyi atlamak ve başlangıç sürelerini hızlandırmak için 'build-only' olarak ayarlayın. */ enabled: true, /** * Çıktı dosyalarının yolunu tanımlar. `outputDir` yerine geçer. * * - `./` ile başlayan yollar bileşen dizinine göre çözümlenir. * - `/` ile başlayan yollar projenin kök dizinine (`baseDir`) göre çözümlenir. * * - Yola `{{locale}}` değişkenini dahil etmek, dile göre ayrılmış sözlüklerin oluşturulmasını etkinleştirir. * * Örnekler: * ```ts * { * // Bileşenin yanına çok dilli .content.ts dosyaları oluşturun * output: ({ fileName, extension }) => `./${fileName}${extension}`, * * // output: './{{fileName}}{{extension}}', // Şablon dizesi kullanarak eşdeğer kullanım * } * ``` * * ```ts * { * // Proje kökünde dile göre merkezileştirilmiş JSON dosyaları oluşturun * output: ({ key, locale }) => `/locales/${locale}/${key}.content.json`, * * // output: '/locales/{{locale}}/{{key}}.content.json', // Şablon dizesi kullanarak eşdeğer kullanım * } * ``` * * Değişken listesi: * - `fileName`: Dosya adı. * - `key`: İçerik anahtarı. * - `locale`: İçerik dili. * - `extension`: Dosya uzantısı. * - `componentFileName`: Bileşen dosya adı. * - `componentExtension`: Bileşen dosya uzantısı. * - `format`: Sözlük formatı. * - `componentFormat`: Bileşen sözlük formatı. * - `componentDirPath`: Bileşen dizin yolu. */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Bileşenlerin dönüştürüldükten sonra kaydedilip kaydedilmeyeceğini belirtir. * Bu şekilde, derleyici uygulamayı dönüştürmek için yalnızca bir kez çalıştırılabilir ve ardından kaldırılabilir. */ saveComponents: false, /** * Oluşturulan dosyaya yalnızca içeriği yerleştirin. Dil başına i18next JSON çıktısı veya ICU MessageFormat için kullanışlıdır. * * - `output: ({ locale, key }) => `./locale/${locale}/${key}.json`,` */ noMetadata: false, /** * Sözlük anahtar öneki */ dictionaryKeyPrefix: "", // Ayıklanan sözlük anahtarları için isteğe bağlı bir önek ekleyin },};Derleyici Yapılandırma Referansı
Aşağıdaki özellikler intlayer.config.ts dosyanızın compiler bloğunda yapılandırılabilir:
enabled:
- Tip:
boolean | 'build-only' - Varsayılan:
true - Açıklama: Derleyicinin etkinleştirilip etkinleştirilmeyeceğini belirtir.
- Tip:
dictionaryKeyPrefix:
- Tip:
string - Varsayılan:
'' - Açıklama: Ayıklanan sözlük anahtarları için önek.
- Tip:
transformPattern:
- Tip:
string | string[] - Varsayılan:
['**/*.{js,ts,mjs,cjs,jsx,tsx,vue,svelte}', '!**/node_modules/**'] - Açıklama: (Kullanımdan kaldırıldı: bunun yerine
build.traversePatternkullanın) Optimize edilecek kodu taramak için desenler.
- Tip:
excludePattern:
- Tip:
string | string[] - Varsayılan:
['**/node_modules/**'] - Açıklama: (Kullanımdan kaldırıldı: bunun yerine
build.traversePatternkullanın) Optimizasyondan hariç tutulacak desenler.
- Tip:
output:
- Tip:
FilePathPattern - Varsayılan:
({ key }) => 'compiler/${key}.content.json' - Açıklama: Çıktı dosyalarının yolunu tanımlar.
outputDiryerine geçer.{{locale}},{{key}},{{fileName}},{{extension}},{{format}},{{dirPath}},{{componentFileName}},{{componentExtension}}, ve{{componentFormat}}gibi dinamik değişkenleri işler.'my/{{var}}/path'formatı kullanılarak bir dize olarak veya bir fonksiyon olarak ayarlanabilir. - Not:
./**/*yolları bileşene göre çözümlenir./**/*yolları IntlayerbaseDir'e göre çözümlenir. - Not: Yolda dil tanımlanmışsa, sözlükler dil başına oluşturulacaktır.
- Örnek:
output: ({ locale, key }) => 'compiler/${locale}/${key}.json'
- Tip:
noMetadata:
- Tip:
boolean - Varsayılan:
false - Açıklama: Meta verilerin dosyaya kaydedilip kaydedilmeyeceğini belirtir. Doğruysa, derleyici sözlüklerin meta verilerini (anahtar, içerik sarmalayıcı) kaydetmez. Dil başına i18next veya ICU MessageFormat JSON çıktıları için kullanışlıdır.
- Not:
loadJSONeklentisi ile kullanıldığında kullanışlıdır. - Örnek:
Eğer
true:json { "key": "value" }Eğerfalse:json { "key": "value", "content": { "key": "value" } }
- Tip:
saveComponents:
- Tip:
boolean - Varsayılan:
false - Açıklama: Bileşenlerin dönüştürüldükten sonra kaydedilip kaydedilmeyeceğini belirtir.
- Tip:
Eksik çevirileri doldur
Intlayer, eksik çevirileri doldurmanıza yardımcı olacak bir CLI aracı sağlar. Kodunuzdaki eksik çevirileri test etmek ve doldurmak için intlayer komutunu kullanabilirsiniz.
Kodu panoya kopyala
npx intlayer test # Eksik çeviri olup olmadığını test etKodu panoya kopyala
npx intlayer fill # Eksik çevirileri doldurÇıkarma
Intlayer, kodunuzdan içerik çıkarmak için bir CLI aracı sağlar. Kodunuzdaki içeriği çıkarmak için intlayer extract komutunu kullanabilirsiniz.
Kodu panoya kopyala
npx intlayer extractDaha fazla ayrıntı için CLI belgelerine bakın.