استخدم مساعدك المفضل للملخص واستخدم هذه الصفحة والموفر AI الذي تريده
تاريخ الإصدارات
- "تحديث استخدام واجهة برمجة تطبيقات useIntlayer في Solid للوصول المباشر إلى الخصائص"v8.9.0٤/٥/٢٠٢٦
- "بدء السجل"v8.4.10٣١/٣/٢٠٢٦
تمت ترجمة محتوى هذه الصفحة باستخدام الذكاء الاصطناعي.
اعرض آخر نسخة المحتوى الأصلي باللغة الإنكليزيةIf 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
ترجمة موقع Vanilla JS الخاص بك باستخدام Intlayer | التدويل (i18n)
جدول المحتويات
لماذا Intlayer على البدائل؟
بالمقارنة مع الحلول الرئيسية مثل i18next أو i18n.js، يعد Intlayer حلاً يأتي مزودًا بتحسينات متكاملة مثل:
تغطية كاملة لـ Vanilla JS
تم تحسين Intlayer للعمل بشكل مثالي مع Vanilla JavaScript من خلال تقديم إدارة محتوى مستقلة عن إطار العمل، ودعم TypeScript، وجميع الميزات اللازمة لتوسيع نطاق التدويل (i18n).
حجم البندل
بدلاً من تحميل ملفات JSON ضخمة إلى صفحاتك، قم بتحميل المحتوى الضروري فقط. يساعد Intlayer في تقليل أحجام البندل وصفحاتك بنسبة تصل إلى 50%.
الصيانة
يؤدي تحديد نطاق محتوى تطبيقك إلى تسهيل الصيانة للتطبيقات واسعة النطاق. يمكنك تكرار أو حذف مجلد ميزات واحد دون العبء العقلي لمراجعة قاعدة بيانات المحتوى بالكامل. بالإضافة إلى ذلك، تتم كتابة Intlayer بالكامل لضمان دقة المحتوى الخاص بك.
وكيل الذكاء الاصطناعي
يؤدي تحديد موقع المحتوى المشترك إلى تقليل السياق المطلوب بواسطة نماذج اللغات الكبيرة (LLMs). يأتي Intlayer أيضًا مزودًا بمجموعة من الأدوات، مثل CLI لاختبار الترجمات المفقودة،LSP، MCP ومهارات الوكيل، لجعل تجربة المطور (DX) أكثر سلاسة للذكاء الاصطناعي وكلاء.
الأتمتة
استخدم الأتمتة للترجمة في مسار CI/CD الخاص بك باستخدام LLM من اختيارك على حساب مزود الذكاء الاصطناعي الخاص بك. يقدم Intlayer أيضًا مترجمًا لأتمتة استخراج المحتوى، بالإضافة إلى منصة ويب للمساعدة في الترجمة في الخلفية.
أداء
يمكن أن يؤدي ربط ملفات JSON الضخمة بالمكونات إلى حدوث مشكلات في الأداء والتفاعل. يعمل Intlayer على تحسين تحميل المحتوى الخاص بك في وقت الإنشاء.
التحجيم مع عدم وجود مطور
أكثر من مجرد حل i18n، يوفر Intlayer [محررًا مرئيًا] مستضافًا ذاتيًا](/ar/doc/concept/editor) وكامل CMS لمساعدتك في إدارة المحتوى متعدد اللغات في الوقت الفعلي، مما يجعل التعاون مع المترجمين ومؤلفي النصوص وأعضاء الفريق الآخرين سلسًا. يمكن تخزين المحتوى محليًا و/أو عن بعد.
دليل خطوة بخطوة لإعداد Intlayer في تطبيق Vanilla JS
تثبيت التبعيات
قم بتثبيت الحزم اللازمة باستخدام npm:
bashنسخ الكودنسخ الكود إلى الحافظة
# إنشاء حزمة مستقلة من intlayer و vanilla-intlayer# سيتم استيراد هذا الملف في ملف HTML الخاص بكnpx intlayer standalone --packages intlayer vanilla-intlayer --outfile intlayer.js# تهيئة intlayer مع ملف التكوينnpx intlayer init --no-gitignore# بناء القواميسnpx intlayer buildintlayer الحزمة الأساسية التي توفر أدوات التدويل لإدارة التكوين والترجمة والتصريح عن المحتوى والتحويل والبرمجة النصية وأوامر CLI.
vanilla-intlayer الحزمة التي تدمج Intlayer مع تطبيقات JavaScript / TypeScript البحتة. توفر كائناً منفرداً للنشر/الاشتراك (
IntlayerClient) ومساعدين يعتمدون على الاستدعاءات (useIntlayer,useLocale, إلخ) بحيث يمكن لأي جزء من تطبيقك التفاعل مع تغييرات اللغة دون الاعتماد على إطار عمل واجهة مستخدم.
ينتج تصدير الربط (bundling) من واجهة سطر أوامر
intlayer standaloneبناءً محسّناً من خلال تقليم الشجرة (tree-shaking) للحزم غير المستخدمة، واللغات، والمنطق غير الأساسي (مثل عمليات إعادة التوجيه أو البوادئ) الخاصة بتكوينك.تكوين مشروعك
قم بإنشاء ملف تكوين لتكوين لغات تطبيقك:
intlayer.config.tsنسخ الكودنسخ الكود إلى الحافظة
import { Locales, type IntlayerConfig } from "intlayer"; const config: IntlayerConfig = { internationalization: { locales: [ Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH, // لغاتك الأخرى ], defaultLocale: Locales.ENGLISH, }, }; export default config;من خلال ملف التكوين هذا، يمكنك إعداد عناوين URL الموطنة، وإعادة توجيه البرامج الوسيطة، وأسماء ملفات تعريف الارتباط، وموقع وامتداد تصريحات المحتوى الخاصة بك، وتعطيل سجلات Intlayer في وحدة التحكم، والمزيد. للحصول على قائمة كاملة بالمعلمات المتاحة، راجع وثائق التكوين.
استيراد الحزمة في HTML الخاص بك
بمجرد إنشاء حزمة
intlayer.js، يمكنك استيرادها في ملف HTML الخاص بك:index.htmlنسخ الكودنسخ الكود إلى الحافظة
<!DOCTYPE html><html lang="ar" dir="rtl"> <head> <meta charset="UTF-8" /> <!-- استيراد الحزمة --> <script src="./intlayer.js" defer></script> <!-- استيراد البرنامج النصي الرئيسي الخاص بك --> <script src="./src/main.js" defer></script> </head> <body> <h1 id="title"></h1> <p class="read-the-docs"></p> </body></html>تكشف الحزمة عن
IntlayerوVanillaIntlayerككائنات عالمية علىwindow.تهيئة Intlayer في نقطة الدخول الخاصة بك
في ملف
src/main.js، قم باستدعاءinstallIntlayer()قبل عرض أي محتوى بحيث يكون الكائن المنفرد للغة العالمية جاهزًا.src/main.jsنسخ الكودنسخ الكود إلى الحافظة
const { installIntlayer } = window.VanillaIntlayer;// يجب استدعاؤه قبل عرض أي محتوى i18n.installIntlayer();إذا كنت تريد أيضًا استخدام عرض markdown ، فقم باستدعاء
installIntlayerMarkdown():src/main.jsنسخ الكودنسخ الكود إلى الحافظة
const { installIntlayer, installIntlayerMarkdown } = window.VanillaIntlayer;installIntlayer();installIntlayerMarkdown();التصريح عن المحتوى الخاص بك
قم بإنشاء وإدارة تصريحات المحتوى الخاصة بك لتخزين الترجمات:
src/app.content.tsنسخ الكودنسخ الكود إلى الحافظة
import { insert, t, type Dictionary } from "intlayer"; const appContent = { key: "app", content: { title: "Vite + Vanilla", viteLogoLabel: t({ en: "Vite Logo", fr: "Logo Vite", es: "Logo Vite", }), count: insert( t({ en: "count is {{count}}", fr: "le compte est {{count}}", es: "el recuento es {{count}}", }) ), readTheDocs: t({ en: "Click on the Vite logo to learn more", fr: "Cliquez sur le logo Vite pour en savoir plus", es: "Haga clic en el logotipo de Vite para obtener más información", }), }, } satisfies Dictionary; export default appContent;يمكن تعريف تصريحات المحتوى الخاصة بك في أي مكان في تطبيقك طالما تم تضمينها في دليل
contentDir(افتراضيًا ،./src). وتطابق امتداد ملف تصريح المحتوى (افتراضيًا ،.content.{json,ts,tsx,js,jsx,mjs,cjs,md,mdx,yaml,yml}).لمزيد من التفاصيل ، راجع وثائق تصريح المحتوى.
استخدام Intlayer في JavaScript الخاص بك
يوفر كائن
window.VanillaIntlayerمساعدين لواجهة البرمجة:useIntlayer(key, locale?)يعيد المحتوى المترجم لمفتاح معين.src/main.jsنسخ الكودنسخ الكود إلى الحافظة
const { installIntlayer, useIntlayer } = window.VanillaIntlayer;installIntlayer();// الحصول على المحتوى الأولي للغة الحالية.// قم بتسلسل .onChange() ليتم إخطارك كلما تغيرت اللغة.const content = useIntlayer("app").onChange((newContent) => { // إعادة عرض أو تعديل عقد DOM المتأثرة فقط document.querySelector("h1").textContent = String(newContent.title); document.querySelector(".read-the-docs").textContent = String( newContent.readTheDocs );});// العرض الأوليdocument.querySelector("h1").textContent = String(content.title);document.querySelector(".read-the-docs").textContent = String( content.readTheDocs);قم بالوصول إلى القيم النهائية كسلاسل من خلال تغليفها في
String()، مما يستدعي طريقةtoString()للعقدة ويعيد النص المترجم.عندما تحتاج إلى القيمة لسمة HTML أصلية (مثل
altوaria-label) ، استخدم.valueمباشرة:javascriptنسخ الكودنسخ الكود إلى الحافظة
img.alt = content.viteLogoLabel.value;تغيير لغة المحتوى الخاص بك
اختياريلتغيير لغة المحتوى الخاص بك ، استخدم وظيفة
setLocaleالتي كشفت عنهاuseLocale.src/locale-switcher.jsنسخ الكودنسخ الكود إلى الحافظة
const { getLocaleName } = window.Intlayer;const { useLocale } = window.VanillaIntlayer;export function setupLocaleSwitcher(container) { const { locale, availableLocales, setLocale, subscribe } = useLocale(); const select = document.createElement("select"); select.setAttribute("aria-label", "اللغة"); const render = (currentLocale) => { select.innerHTML = availableLocales .map( (loc) => `<option value="${loc}"${loc === currentLocale ? " selected" : ""}> ${getLocaleName(loc)} </option>` ) .join(""); }; render(locale); container.appendChild(select); select.addEventListener("change", () => setLocale(select.value)); // الحفاظ على مزامنة القائمة المنسدلة عند تغير اللغة من مكان آخر return subscribe((newLocale) => render(newLocale));}تبديل سمات لغة HTML والاتجاه
اختياريقم بتحديث سمات
langوdirلعلامة<html>لمطابقة اللغة الحالية لتسهيل الوصول وتحسين محركات البحث.src/main.jsنسخ الكودنسخ الكود إلى الحافظة
const { getHTMLTextDir } = window.Intlayer;const { installIntlayer, useLocale } = window.VanillaIntlayer;installIntlayer();useLocale({ onLocaleChange: (locale) => { document.documentElement.lang = locale; document.documentElement.dir = getHTMLTextDir(locale); },});تحميل القواميس بكسل لكل لغة
اختياريإذا كنت ترغب في تحميل القواميس بكسل (lazy-load) لكل لغة ، يمكنك استخدام
useDictionaryDynamic. هذا مفيد إذا كنت لا تريد حزم جميع الترجمات في ملفintlayer.jsالأولي.src/app.jsنسخ الكودنسخ الكود إلى الحافظة
const { installIntlayer, useDictionaryDynamic } = window.VanillaIntlayer;installIntlayer();const unsubscribe = useDictionaryDynamic( { en: () => import("../.intlayer/dictionaries/en/app.mjs"), fr: () => import("../.intlayer/dictionaries/fr/app.mjs"), es: () => import("../.intlayer/dictionaries/es/app.mjs"), }, "app").onChange((content) => { document.querySelector("h1").textContent = String(content.title);});ملاحظة: يتطلب
useDictionaryDynamicتوفر القواميس كملفات ESM منفصلة. يتم استخدام هذا النهج عادةً إذا كان لديك خادم ويب يقدم القواميس.
تكوين TypeScript
تأكد من أن تكوين TypeScript الخاص بك يتضمن الأنواع التي تم إنشاؤها تلقائيًا.
نسخ الكود إلى الحافظة
{ "compilerOptions": { // ... }, "include": ["src", ".intlayer/**/*.ts"],}امتداد VS Code
لتحسين تجربة التطوير الخاصة بك مع Intlayer ، يمكنك تثبيت امتداد Intlayer VS Code الرسمي.
التثبيت من VS Code Marketplace
يوفر هذا الامتداد:
- الإكمال التلقائي لمفاتيح الترجمة.
- اكتشاف الأخطاء في الوقت الفعلي للترجمات المفقودة.
- معاينات مضمنة للمحتوى المترجم.
- إجراءات سريعة لإنشاء وتحديث الترجمات بسهولة.
لمزيد من التفاصيل حول كيفية استخدام الامتداد ، راجع وثائق امتداد Intlayer VS Code.
اذهب أبعد من ذلك
للذهاب إلى أبعد من ذلك ، يمكنك تنفيذ المحرر المرئي أو استضافة محتواك خارجيًا باستخدام CMS.