Ajukan pertanyaan Anda dan dapatkan ringkasan dokumen dengan merujuk halaman ini dan penyedia AI pilihan Anda
Riwayat Versi
- "Perbarui penggunaan API useIntlayer Solid ke akses properti langsung"v8.9.04/5/2026
- "Tambahkan perintah init"v7.5.930/12/2025
- "Inisialisasi riwayat"v7.1.1020/11/2025
Konten halaman ini diterjemahkan menggunakan AI.
Lihat versi terakhir dari konten aslinya dalam bahasa InggrisIf 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
Terjemahkan situs web SvelteKit Anda menggunakan Intlayer | Internasionalisasi (i18n)
Daftar Isi
Mengapa Intlayer dibandingkan alternatif?
Dibandingkan dengan solusi utama seperti svelte-i18n atau i18next, Intlayer adalah solusi yang hadir dengan pengoptimalan terintegrasi seperti:
Intlayer dioptimalkan untuk bekerja sempurna dengan SvelteKit dengan menawarkan perutean multibahasa, dukungan SSR, dan semua fitur yang diperlukan untuk penskalaan internasionalisasi (i18n).
Daripada memuat file JSON berukuran besar ke halaman Anda, muat saja konten yang diperlukan. Intlayer membantu mengurangi ukuran bundle dan halaman Anda hingga 50%.
Mencakup konten aplikasi Anda memfasilitasi pemeliharaan untuk aplikasi berskala besar. Anda dapat menduplikasi atau menghapus satu folder fitur tanpa beban mental untuk meninjau seluruh basis kode konten Anda. Selain itu, Intlayer diketik sepenuhnya untuk memastikan keakuratan konten Anda.
Menempatkan konten bersama mengurangi konteks yang diperlukan dengan Model Bahasa Besar (LLM). Intlayer juga dilengkapi dengan serangkaian alat, seperti CLI untuk menguji terjemahan yang hilang,LSP, MCP, dan agent skill, untuk menjadikan pengalaman pengembang (DX) lebih lancar bagi agen AI.
Gunakan otomatisasi untuk menerjemahkan dalam saluran CI/CD Anda menggunakan LLM pilihan Anda dengan biaya penyedia AI Anda. Intlayer juga menawarkan compiler untuk mengotomatiskan ekstraksi konten, serta platform web untuk membantu menerjemahkan di latar belakang.
Menghubungkan file JSON berukuran besar ke komponen dapat menyebabkan masalah kinerja dan reaktivitas. Intlayer mengoptimalkan pemuatan konten Anda pada waktu pembuatan.
Lebih dari sekedar solusi i18n, Intlayer menyediakan editor visual yang dihosting sendiri dan CMS lengkap untuk membantu Anda mengelola konten multibahasa secara real-time, membuat kolaborasi dengan penerjemah, copywriter, dan anggota tim lainnya menjadi lancar. Konten dapat disimpan secara lokal dan/atau jarak jauh.
Panduan Langkah demi Langkah untuk Mengatur Intlayer dalam Aplikasi SvelteKit
Untuk memulai, buat proyek SvelteKit baru. Berikut adalah struktur akhir yang akan kita buat:
Salin kode ke clipboard
.├── intlayer.config.ts├── package.json├── src│ ├── app.d.ts│ ├── app.html│ ├── hooks.server.ts│ ├── lib│ │ ├── getLocale.ts│ │ ├── LocaleSwitcher.svelte│ │ └── LocalizedLink.svelte│ ├── params│ │ └── locale.ts│ └── routes│ ├── [[locale=locale]]│ │ ├── +layout.svelte│ │ ├── +layout.ts│ │ ├── +page.svelte│ │ ├── +page.ts│ │ ├── about│ │ │ ├── +page.svelte│ │ │ ├── +page.ts│ │ │ └── page.content.ts│ │ ├── Counter.content.ts│ │ ├── Counter.svelte│ │ ├── Header.content.ts│ │ ├── Header.svelte│ │ ├── home.content.ts│ │ └── layout.content.ts│ ├── +layout.svelte│ └── layout.css├── static│ ├── favicon.svg│ └── robots.txt├── svelte.config.js├── tsconfig.json└── vite.config.tsInstalasi Dependencies
Instal paket yang diperlukan menggunakan npm:
bashSalin kodeSalin kode ke clipboard
npm install intlayer svelte-intlayernpm install vite-intlayer --save-devnpx intlayer init- intlayer: Paket inti i18n.
- svelte-intlayer: Menyediakan context providers dan stores untuk Svelte/SvelteKit.
- vite-intlayer: Plugin Vite untuk mengintegrasikan deklarasi konten dengan proses build.
Konfigurasi proyek Anda
Buat file konfigurasi di root proyek Anda:
intlayer.config.tsSalin kodeSalin kode ke clipboard
import { Locales, type IntlayerConfig } from "intlayer";const config: IntlayerConfig = { internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], defaultLocale: Locales.ENGLISH, },};export default config;Integrasikan Intlayer dalam Konfigurasi Vite Anda
Perbarui
vite.config.tsAnda untuk menyertakan plugin Intlayer. Plugin ini menangani transpile file konten Anda.vite.config.tsSalin kodeSalin kode ke clipboard
import { sveltekit } from "@sveltejs/kit/vite";import { defineConfig } from "vite";import { intlayer } from "vite-intlayer";export default defineConfig({ plugins: [intlayer(), sveltekit()], // urutan penting, Intlayer harus ditempatkan sebelum SvelteKit});Deklarasikan Konten Anda
Buat file deklarasi konten Anda di mana saja dalam folder
srcAnda (misalnya,src/lib/contentatau di samping komponen Anda). File-file ini mendefinisikan konten yang dapat diterjemahkan untuk aplikasi Anda menggunakan fungsit()untuk setiap locale.Gunakan Intlayer dalam Komponen Anda
Sekarang Anda dapat menggunakan fungsi
useIntlayerdi komponen Svelte mana pun. Fungsi ini mengembalikan store reaktif yang secara otomatis diperbarui saat locale berubah. Fungsi ini akan secara otomatis menghormati locale saat ini (baik selama SSR maupun navigasi sisi klien).Catatan:
useIntlayermengembalikan store Svelte, jadi Anda perlu menggunakan prefix `--- createdAt: 2025-11-20 updatedAt: 2026-05-31 title: Cara menerjemahkan aplikasi SvelteKit Anda – panduan i18n 2026 description: Temukan cara membuat situs web SvelteKit Anda menjadi multibahasa. Ikuti dokumentasi untuk melakukan internasionalisasi (i18n) dan menerjemahkannya menggunakan Server-Side Rendering (SSR). keywords:- Internasionalisasi
- Dokumentasi
- Intlayer
- SvelteKit
- JavaScript
- SSR slugs:
- doc
- environment
- sveltekit applicationTemplate: https://github.com/aymericzip/intlayer-sveltekit-template history:
- version: 7.1.10 date: 2025-11-20 changes: Inisialisasi riwayat
Terjemahkan situs web SvelteKit Anda menggunakan Intlayer | Internasionalisasi (i18n)
Daftar Isi
Apa itu Intlayer?
Intlayer adalah perpustakaan internasionalisasi (i18n) sumber terbuka yang inovatif, dirancang untuk menyederhanakan dukungan multibahasa dalam aplikasi web modern. Ini bekerja mulus dengan kemampuan Server-Side Rendering (SSR) dari SvelteKit.
Dengan Intlayer, Anda dapat:
- Mengelola terjemahan dengan mudah menggunakan kamus deklaratif di tingkat komponen.
- Melokalkan metadata, rute, dan konten secara dinamis.
- Memastikan dukungan TypeScript dengan tipe yang dihasilkan secara otomatis.
- Memanfaatkan SSR SvelteKit untuk internasionalisasi yang ramah SEO.
Panduan Langkah demi Langkah untuk Mengatur Intlayer dalam Aplikasi SvelteKit
Untuk memulai, buat proyek SvelteKit baru. Berikut adalah struktur akhir yang akan kita buat:
Salin kode ke clipboard
.├── intlayer.config.ts├── package.json├── src│ ├── app.d.ts│ ├── app.html│ ├── hooks.server.ts│ ├── lib│ │ ├── getLocale.ts│ │ ├── LocaleSwitcher.svelte│ │ └── LocalizedLink.svelte│ ├── params│ │ └── locale.ts│ └── routes│ ├── [[locale=locale]]│ │ ├── +layout.svelte│ │ ├── +layout.ts│ │ ├── +page.svelte│ │ ├── +page.ts│ │ ├── about│ │ │ ├── +page.svelte│ │ │ ├── +page.ts│ │ │ └── page.content.ts│ │ ├── Counter.content.ts│ │ ├── Counter.svelte│ │ ├── Header.content.ts│ │ ├── Header.svelte│ │ ├── home.content.ts│ │ └── layout.content.ts│ ├── +layout.svelte│ └── layout.css├── static│ ├── favicon.svg│ └── robots.txt├── svelte.config.js├── tsconfig.json└── vite.config.tsInstalasi Dependencies
Instal paket yang diperlukan menggunakan npm:
bashSalin kodeSalin kode ke clipboard
npm install intlayer svelte-intlayernpm install vite-intlayer --save-devnpx intlayer init- intlayer: Paket inti i18n.
- svelte-intlayer: Menyediakan context providers dan stores untuk Svelte/SvelteKit.
- vite-intlayer: Plugin Vite untuk mengintegrasikan deklarasi konten dengan proses build.
Konfigurasi proyek Anda
Buat file konfigurasi di root proyek Anda:
intlayer.config.tsSalin kodeSalin kode ke clipboard
import { Locales, type IntlayerConfig } from "intlayer";const config: IntlayerConfig = { internationalization: { locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], defaultLocale: Locales.ENGLISH, },};export default config;Integrasikan Intlayer dalam Konfigurasi Vite Anda
Perbarui
vite.config.tsAnda untuk menyertakan plugin Intlayer. Plugin ini menangani transpile file konten Anda.vite.config.tsSalin kodeSalin kode ke clipboard
import { sveltekit } from "@sveltejs/kit/vite";import { defineConfig } from "vite";import { intlayer } from "vite-intlayer";export default defineConfig({ plugins: [intlayer(), sveltekit()], // urutan penting, Intlayer harus ditempatkan sebelum SvelteKit});Deklarasikan Konten Anda
Buat file deklarasi konten Anda di mana saja dalam folder
srcAnda (misalnya,src/lib/contentatau di samping komponen Anda). File-file ini mendefinisikan konten yang dapat diterjemahkan untuk aplikasi Anda menggunakan fungsit()untuk setiap locale.Gunakan Intlayer dalam Komponen Anda
untuk mengakses nilai reaktifnya (misalnya,
$content.title).src/lib/components/Component.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; // "hero-section" sesuai dengan key yang didefinisikan di Langkah 4 const content = useIntlayer("hero-section");</script><!-- Render konten sebagai konten sederhana --><h1>{$content.title}</h1><!-- Untuk merender konten yang dapat diedit menggunakan editor --><h1>{@const Title = $content.title}<Title /></h1><!-- Untuk merender konten sebagai string --><div aria-label={$content.title.value}></div><div aria-label={$content.title.toString()}></div><div aria-label={String($content.title)}></div>Atur routing
OpsionalLangkah-langkah berikut menunjukkan cara mengatur routing berbasis locale di SvelteKit. Ini memungkinkan URL Anda menyertakan prefix locale (misalnya,
/en/about,/fr/about) untuk SEO yang lebih baik dan pengalaman pengguna yang lebih baik.bashSalin kodeSalin kode ke clipboard
.└─── src ├── app.d.ts # Mendefinisikan tipe locale ├── hooks.server.ts # Mengelola routing locale ├── lib │ └── getLocale.ts # Memeriksa locale dari header, cookies ├── params │ └── locale.ts # Mendefinisikan parameter locale └── routes ├── [[locale=locale]] # Bungkus dalam grup route untuk mengatur locale │ ├── +layout.svelte # Tata letak lokal untuk rute │ ├── +layout.ts │ ├── +page.svelte │ ├── +page.ts │ └── about │ ├── +page.svelte │ └── +page.ts └── +layout.svelte # Tata letak root untuk font dan gaya globalTangani Deteksi Locale di Server
Di SvelteKit, server perlu mengetahui locale pengguna untuk merender konten yang benar selama SSR. Kita menggunakan
hooks.server.tsuntuk mendeteksi locale dari URL atau cookie.Buat atau modifikasi
src/hooks.server.ts:src/hooks.server.tsSalin kodeSalin kode ke clipboard
import type { Handle } from "@sveltejs/kit";import { getLocalizedUrl } from "intlayer";import { getLocale } from "$lib/getLocale";export const handle: Handle = async ({ event, resolve }) => { const detectedLocale = getLocale(event); // Periksa apakah path saat ini sudah diawali dengan locale (misal /fr, /en) const pathname = event.url.pathname; const targetPathname = getLocalizedUrl(pathname, detectedLocale); // Jika TIDAK ada locale dalam URL (misal pengguna mengunjungi "/"), arahkan ulang mereka if (targetPathname !== pathname) { return new Response(undefined, { headers: { Location: targetPathname }, status: 307, // Redirect sementara }); } return resolve(event, { transformPageChunk: ({ html }) => html.replace("%lang%", detectedLocale), });};Kemudian, buat helper untuk mendapatkan locale pengguna dari event request:
src/lib/getLocale.tsSalin kodeSalin kode ke clipboard
import { configuration, getLocaleFromStorage, localeDetector, type Locale,} from "intlayer";import type { RequestEvent } from "@sveltejs/kit";/** * Mendapatkan locale pengguna dari event request. * Fungsi ini digunakan dalam hook `handle` di `src/hooks.server.ts`. * * Pertama-tama mencoba mendapatkan locale dari penyimpanan Intlayer (cookies atau header khusus). * Jika locale tidak ditemukan, maka menggunakan fallback negosiasi "Accept-Language" dari browser. * * @param event - Event request dari SvelteKit * @returns Locale pengguna */export const getLocale = (event: RequestEvent): Locale => { const defaultLocale = configuration?.internationalization?.defaultLocale; // Mencoba mendapatkan locale dari penyimpanan Intlayer (Cookies atau header) const storedLocale = getLocaleFromStorage({ // Akses cookie SvelteKit getCookie: (name: string) => event.cookies.get(name) ?? null, // Akses header SvelteKit getHeader: (name: string) => event.request.headers.get(name) ?? null, }); if (storedLocale) { return storedLocale; } // Cadangan ke negosiasi "Accept-Language" browser const negotiatorHeaders: Record<string, string> = {}; // Mengonversi objek Headers SvelteKit menjadi Record<string, string> biasa event.request.headers.forEach((value, key) => { negotiatorHeaders[key] = value; }); // Periksa locale dari header `Accept-Language` const userFallbackLocale = localeDetector(negotiatorHeaders); if (userFallbackLocale) { return userFallbackLocale; } // Kembalikan locale default jika tidak ada yang cocok ditemukan return defaultLocale;};getLocaleFromStorageakan memeriksa locale dari header atau cookie tergantung pada konfigurasi Anda. Lihat Configuration untuk detail lebih lanjut.Fungsi
localeDetectorakan memproses headerAccept-Languagedan mengembalikan kecocokan terbaik.Jika locale tidak dikonfigurasi, kita ingin mengembalikan error 404. Untuk mempermudah, kita dapat membuat fungsi
matchuntuk memeriksa apakah locale valid:/src/params/locale.tsSalin kodeSalin kode ke clipboard
export const match = (param: Locale = defaultLocale): boolean => locales.includes(param);Catatan: Pastikan
src/app.d.tsAnda menyertakan definisi locale:typescriptSalin kodeSalin kode ke clipboard
declare global { namespace App { interface Locals { locale: import("intlayer").Locale; } }}Untuk file
+layout.svelte, kita dapat menghapus semuanya, agar hanya menyimpan konten statis yang tidak terkait dengan i18n:src/+layout.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import './layout.css'; let { children } = $props();</script><div class="app"> {@render children()}</div><style> .app { /* */ }</style>Kemudian, buat halaman dan layout baru di bawah grup
[[locale=locale]]:src/routes/[[locale=locale]]/+layout.tsSalin kodeSalin kode ke clipboard
import type { Load } from "@sveltejs/kit";import { defaultLocale, type Locale } from "intlayer";export const prerender = true;// Gunakan tipe Load generikexport const load: Load = ({ params }) => { const locale: Locale = (params.locale as Locale) ?? defaultLocale; return { locale, };};src/routes/[[locale=locale]]/+layout.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import type { Snippet } from 'svelte'; import { useIntlayer, setupIntlayer } from "svelte-intlayer"; import Header from './Header.svelte'; import type { LayoutData } from './$types'; let { children, data }: { children: Snippet, data: LayoutData } = $props(); // Inisialisasi Intlayer dengan locale dari route $effect(() => { setupIntlayer(data.locale); }); // Gunakan kamus konten layout const layoutContent = useIntlayer('layout');</script><Header /><main> {@render children()}</main><footer> <p> {$layoutContent.footer.prefix.value}{' '} <a href="https://svelte.dev/docs/kit">{$layoutContent.footer.linkLabel.value}</a>{' '} {$layoutContent.footer.suffix.value} </p></footer><style> /* */</style>src/routes/[[locale=locale]]/+page.tsSalin kodeSalin kode ke clipboard
export const prerender = true;src/routes/[[locale=locale]]/+page.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; // Gunakan kamus konten home const homeContent = useIntlayer('home');</script><svelte:head> <title>{$homeContent.title.value}</title></svelte:head><section> <h1> {$homeContent.title} </h1></section><style> /* */</style>Tautan Internasionalisasi
OpsionalUntuk SEO, disarankan untuk menambahkan prefix locale pada rute Anda (misalnya,
/en/about,/fr/about). Komponen ini secara otomatis menambahkan prefix locale saat ini pada setiap tautan.src/lib/components/LocalizedLink.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import { getLocalizedUrl } from "intlayer"; import { useLocale } from "svelte-intlayer"; let { href = "" } = $props(); const { locale } = useLocale(); // Bantuan untuk menambahkan prefix URL dengan locale saat ini $: localizedHref = getLocalizedUrl(href, $locale);</script><a href={localizedHref}> <slot /></a>Jika Anda menggunakan
gotodari SvelteKit, Anda dapat menggunakan logika yang sama dengangetLocalizedUrluntuk menavigasi ke URL yang sudah dilokalkan:typescriptSalin kodeSalin kode ke clipboard
import { goto } from "$app/navigation";import { getLocalizedUrl } from "intlayer";import { useLocale } from "svelte-intlayer";const { locale } = useLocale();const localizedPath = getLocalizedUrl("/about", $locale);goto(localizedPath); // Menavigasi ke /en/about atau /fr/about tergantung localePengalih Bahasa
OpsionalUntuk memungkinkan pengguna mengganti bahasa, perbarui URL.
src/lib/components/LanguageSwitcher.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import { getLocalizedUrl, getLocaleName } from 'intlayer'; import { useLocale } from "svelte-intlayer"; import { page } from '$app/stores'; import { goto } from '$app/navigation'; const { locale, setLocale, availableLocales } = useLocale({ onLocaleChange: (newLocale) => { const localizedPath = getLocalizedUrl($page.url.pathname, newLocale); goto(localizedPath); }, });</script><ul class="locale-list"> {#each availableLocales as localeEl} <li> <a href={getLocalizedUrl($page.url.pathname, localeEl)} onclick={(e) => { e.preventDefault(); setLocale(localeEl); // Akan mengatur locale di store dan memicu onLocaleChange }} class:active={$locale === localeEl} > {getLocaleName(localeEl)} </a> </li> {/each}</ul><style> /* */</style>Tambahkan proxy backend
OpsionalUntuk menambahkan proxy backend ke aplikasi SvelteKit Anda, Anda dapat menggunakan fungsi
intlayerProxyyang disediakan oleh pluginvite-intlayer. Plugin ini akan secara otomatis mendeteksi locale terbaik untuk pengguna berdasarkan URL, cookie, dan preferensi bahasa browser.vite.config.tsSalin kodeSalin kode ke clipboard
import { defineConfig } from "vite";import { intlayer, intlayerProxy } from "vite-intlayer";import { sveltekit } from "@sveltejs/kit/vite";// https://vitejs.dev/config/export default defineConfig({ plugins: [ intlayerProxy(), // should be placed first intlayer(), sveltekit(), ],],});Mengatur editor / CMS intlayer
OpsionalUntuk mengatur editor intlayer, Anda harus mengikuti dokumentasi editor intlayer.
Untuk mengatur CMS intlayer, Anda harus mengikuti dokumentasi CMS intlayer.
Untuk dapat memvisualisasikan selector editor intlayer, Anda harus menggunakan sintaks komponen dalam konten intlayer Anda.
Component.svelteSalin kodeSalin kode ke clipboard
<script lang="ts"> import { useIntlayer } from "svelte-intlayer"; const content = useIntlayer("component");</script><div> <!-- Render konten sebagai konten sederhana --> <h1>{$content.title}</h1> <!-- Render konten sebagai komponen (diperlukan oleh editor) --> {@const Component = $content.component}<Component /></div>Ekstrak konten komponen Anda
OpsionalJika Anda memiliki basis kode yang ada, mengubah ribuan file bisa memakan waktu lama.
Untuk memudahkan proses ini, Intlayer mengusulkan compiler / extractor untuk mengubah komponen Anda dan mengekstrak kontennya.
Untuk mengaturnya, Anda dapat menambahkan bagian
compilerdi fileintlayer.config.tsAnda:intlayer.config.tsSalin kodeSalin kode ke clipboard
import { type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { // ... Sisa konfigurasi Anda compiler: { /** * Menunjukkan apakah compiler harus diaktifkan. */ enabled: true, /** * Menentukan jalur file output */ output: ({ fileName, extension }) => `./${fileName}${extension}`, /** * Menunjukkan apakah komponen harus disimpan setelah diubah. Dengan begitu, compiler dapat dijalankan satu kali saja untuk mengubah aplikasi, lalu dapat dihapus. */ saveComponents: false, /** * Prefiks kunci kamus */ dictionaryKeyPrefix: "", }, }; export default config;Jalankan extractor untuk mengubah komponen Anda dan mengekstrak kontennya
bashSalin kodeSalin kode ke clipboard
npx intlayer extract
Konfigurasi Git
Disarankan untuk mengabaikan file-file yang dihasilkan oleh Intlayer.
Salin kode ke clipboard
# Abaikan file-file yang dihasilkan oleh Intlayer.intlayerMelangkah Lebih Jauh
- Editor Visual: Integrasikan Intlayer Visual Editor untuk mengedit terjemahan langsung dari UI.
- CMS: Eksternalisasi manajemen konten Anda menggunakan Intlayer CMS.