استخدم مساعدك المفضل للملخص واستخدم هذه الصفحة والموفر AI الذي تريده
تاريخ الإصدارات
- "تحديث استخدام واجهة برمجة تطبيقات useIntlayer في Solid للوصول المباشر إلى الخصائص"v8.9.0٤/٥/٢٠٢٦
- "تمت الإضافة لـ Tanstack Start Solid.js"v8.5.1٢٥/٣/٢٠٢٦
تمت ترجمة محتوى هذه الصفحة باستخدام الذكاء الاصطناعي.
اعرض آخر نسخة المحتوى الأصلي باللغة الإنكليزية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
ترجم موقعك على Tanstack Start مع Solid.js باستخدام Intlayer | التدويل (i18n)
جدول المحتويات
يوضح هذا الدليل كيفية دمج Intlayer من أجل تدويل سلس في مشاريع Tanstack Start مع Solid.js، وتوجيه مدرك للغة، ودعم TypeScript، وممارسات التطوير الحديثة.
ما هو Intlayer؟
Intlayer هو مكتبة تدويل (i18n) مبتكرة ومفتوحة المصدر مصممة لتبسيط الدعم متعدد اللغات في تطبيقات الويب الحديثة.
باستخدام Intlayer، يمكنك:
- إدارة الترجمات بسهولة باستخدام قواميس تعريفية على مستوى المكون.
- توطين العناوين (metadata) والمسارات والمحتوى ديناميكيًا.
- ضمان دعم TypeScript من خلال الأنواع المنشأة تلقائيًا، مما يحسن الإكمال التلقائي واكتشاف الأخطاء.
- الاستفادة من الميزات المتقدمة، مثل الاكتشاف والتبديل الديناميكي للغة.
- تفعيل التوجيه المدرك للغة باستخدام نظام التوجيه القائم على الملفات في Tanstack Start.
دليل خطوة بخطوة لإعداد Intlayer في تطبيق Tanstack Start
شاهد قالب التطبيق على GitHub.
الخطوة 1: إنشاء المشروع
ابدأ بإنشاء مشروع TanStack Start جديد باتباع دليل بدء مشروع جديد على موقع TanStack Start.
الخطوة 2: تثبيت حزم Intlayer
قم بتثبيت الحزم اللازمة باستخدام مدير الحزم المفضل لديك:
نسخ الكود إلى الحافظة
npm install intlayer solid-intlayernpm install vite-intlayer --save-devnpx intlayer initintlayer
الحزمة الأساسية التي توفر أدوات التدويل لإدارة الإعدادات، الترجمة، إعلان المحتوى، والتحويل البرمجي وأوامر واجهة الأوامر (CLI).
solid-intlayer الحزمة التي تدمج Intlayer مع تطبيقات Solid. توفر مجمعات السياق (context providers) والخطافات (hooks) للتدويل في Solid.
vite-intlayer تتضمن إضافة Vite لدمج Intlayer مع أداة بناء Vite، كذالك البرمجيات الوسيطة (middleware) لاكتشاف اللغة المفضلة للمستخدم، وإدارة ملفات تعريف الارتباط (cookies)، والتعامل مع إعادة توجيه الروابط.
الخطوة 3: إعداد مشروعك
قم بإنشاء ملف إعدادات لتكوين اللغات في تطبيقك:
نسخ الكود إلى الحافظة
import type { IntlayerConfig } from "intlayer";import { Locales } from "intlayer";const config: IntlayerConfig = { internationalization: { defaultLocale: Locales.ENGLISH, locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH], },};export default config;من خلال ملف الإعدادات هذا، يمكنك تكوين الروابط المترجمة، إعادة توجيه البرمجيات الوسيطة، أسماء ملفات تعريف الارتباط، وموقع وامتداد إعلانات المحتوى الخاصة بك، وتعطيل سجلات Intlayer في وحدة التحكم، والمزيد. للحصول على قائمة كاملة بالمعلمات المتاحة، راجع توثيق الإعدادات.
الخطوة 4: دمج Intlayer في إعدادات Vite الخاصة بك
أضف إضافة intlayer إلى إعداداتك:
نسخ الكود إلى الحافظة
import { intlayer } from "vite-intlayer";import { defineConfig } from "vite";import { devtools } from "@tanstack/devtools-vite";import { tanstackStart } from "@tanstack/solid-start/plugin/vite";import solidPlugin from "vite-plugin-solid";export default defineConfig({ plugins: [ devtools(), tanstackStart({ router: { routeFileIgnorePattern: ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$", }, }), solidPlugin({ ssr: true }), intlayer(), ],});تُستخدم إضافة intlayer() لـ Vite لدمج Intlayer مع Vite. تضمن بناء ملفات إعلان المحتوى ومراقبتها في وضع التطوير. وتعرّف متغيرات بيئة Intlayer داخل تطبيق Vite. بالإضافة إلى ذلك، توفر أسماء بديلة (aliases) لتحسين الأداء.
الخطوة 5: إنشاء التخطيط الجذري (Root Layout)
قم بتكوين التخطيط الجذري الخاص بك لدعم التدويل باستخدام useParams لاكتشاف اللغة الحالية وتعيين سمات lang و dir على وسم html.
نسخ الكود إلى الحافظة
import { HeadContent, Scripts, createRootRouteWithContext,} from "@tanstack/solid-router";import { HydrationScript } from "solid-js/web";import { Suspense, type ParentComponent } from "solid-js";import { IntlayerProvider } from "solid-intlayer";import { defaultLocale, getHTMLTextDir } from "intlayer";import { Route as LocaleRoute } from "./{-$locale}/route";export const Route = createRootRouteWithContext()({ shellComponent: RootComponent,});const RootComponent: ParentComponent = (props) => { const params = LocaleRoute.useParams(); const locale = params()?.locale ?? defaultLocale; return ( <html dir={getHTMLTextDir(locale)} lang={locale}> <head> <HydrationScript /> <HeadContent /> </head> <body> <IntlayerProvider locale={locale}> <Suspense>{props.children}</Suspense> </IntlayerProvider> <Scripts /> </body> </html> );};الخطوة 6: إنشاء تخطيط اللغة (اختياري)
أنشئ تخطيطًا يتعامل مع بادئة اللغة ويقوم بالتحقق من صحتها. سيضمن هذا التخطيط معالجة اللغات الصالحة فقط.
هذه الخطوة اختيارية إذا لم تكن بحاجة إلى التحقق من بادئة اللغة على مستوى المسار.
نسخ الكود إلى الحافظة
import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";import { validatePrefix } from "intlayer";export const Route = createFileRoute("/{-$locale}")({ beforeLoad: ({ params }) => { const localeParam = params.locale; // التحقق من بادئة اللغة const { isValid, localePrefix } = validatePrefix(localeParam); if (!isValid) { throw redirect({ to: "/{-$locale}/404", params: { locale: localePrefix }, replace: true, }); } }, component: Outlet,});هنا،{-$locale}هو معلمة مسار ديناميكية يتم استبدالها باللغة الحالية. هذا التنسيق يجعل الجزء اختياريًا، مما يسمح له بالعمل مع أوضاع التوجيه مثل'prefix-no-default'وغيرها.
كن على علم بأن هذا الجزء قد يسبب مشكلات إذا كنت تستخدم أجزاء ديناميكية متعددة في نفس المسار (مثل:
/{-$locale}/other-path/$anotherDynamicPath/...). لوضع'prefix-all'، قد تفضل تبديل الجزء إلى$locale. لوضع'no-prefix'أو'search-params'، يمكنك إزالة الجزء تمامًا.
الخطوة 7: إعلان المحتوى الخاص بك
قم بإنشاء وإدارة إعلانات المحتوى الخاصة بك لتخزين الترجمات:
نسخ الكود إلى الحافظة
import type { Dictionary } from "intlayer";import { t } from "intlayer";const appContent = { content: { links: { about: t({ en: "About", es: "Acerca de", fr: "À propos", }), home: t({ en: "Home", es: "Inicio", fr: "Accueil", }), }, meta: { title: t({ en: "Welcome to Intlayer + TanStack Router", es: "Bienvenido a Intlayer + TanStack Router", fr: "Bienvenue à Intlayer + TanStack Router", }), description: t({ en: "This is an example of using Intlayer with TanStack Router", es: "Este es un ejemplo de uso de Intlayer con TanStack Router", fr: "Ceci est un exemple d'utilisation d'Intlayer avec TanStack Router", }), }, }, key: "app",} satisfies Dictionary;export default appContent;يمكن تعريف إعلانات المحتوى الخاصة بك في أي مكان في تطبيقك، طالما أنها مضمنة في مجلدcontentDir(افتراضيًا./app). وتطابق امتداد ملفات إعلان المحتوى (افتراضيًا.content.{json,ts,tsx,js,jsx,mjs,cjs}).
لمزيد من التفاصيل، راجع توثيق إعلان المحتوى.
الخطوة 8: استخدام المكونات والخطافات المدركة للغة
قم بإنشاء مكون LocalizedLink للتنقل المدرك للغة:
نسخ الكود إلى الحافظة
import { Link, type LinkProps } from "@tanstack/solid-router";import { getPrefix } from "intlayer";import { useLocale } from "solid-intlayer";import type { JSX } from "solid-js";export const LOCALE_ROUTE = "{-$locale}" as const;export type RemoveLocaleParam<TVal> = TVal extends string ? RemoveLocaleFromString<TVal> : TVal;export type To = RemoveLocaleParam<LinkProps["to"]>;type CollapseDoubleSlashes<TString extends string> = TString extends `${infer THead}//${infer TTail}` ? CollapseDoubleSlashes<`${THead}/${TTail}`> : TString;export type LocalizedLinkProps = Omit<LinkProps, "to"> & { to?: To;} & JSX.AnchorHTMLAttributes<HTMLAnchorElement>;type RemoveAll< TString extends string, TSub extends string,> = TString extends `${infer THead}${TSub}${infer TTail}` ? RemoveAll<`${THead}${TTail}`, TSub> : TString;type RemoveLocaleFromString<TString extends string> = CollapseDoubleSlashes< RemoveAll<TString, typeof LOCALE_ROUTE>>;export const LocalizedLink = (props: LocalizedLinkProps) => { const { locale } = useLocale(); return ( <Link {...props} params={{ locale: getPrefix(locale()).localePrefix, ...(typeof props.params === "object" ? props.params : {}), }} to={`/${LOCALE_ROUTE}${props.to ?? ""}` as LinkProps["to"]} /> );};يخدم هذا المكون غرضين:
- إزالة بادئة
{-$locale}غير الضرورية من الروابط. - حقن معلمة اللغة في الروابط لضمان إعادة توجيه المستخدم مباشرة إلى المسار المترجم.
بعد ذلك، يمكننا إنشاء خطاف useLocalizedNavigate للتنقل البرمجي:
نسخ الكود إلى الحافظة
import { useNavigate } from "@tanstack/solid-router";import { getLocalizedUrl } from "intlayer";import { useLocale } from "solid-intlayer";export const useLocalizedNavigate = () => { const navigate = useNavigate(); const { locale } = useLocale(); const localizedNavigate = (to: string) => { const localizedTo = getLocalizedUrl(to, locale()); return navigate({ to: localizedTo }); }; return localizedNavigate;};الخطوة 9: استخدام Intlayer في صفحاتك
قم بالوصول إلى قواميس المحتوى الخاصة بك عبر تطبيقك:
صفحة رئيسية مترجمة
نسخ الكود إلى الحافظة
import { createFileRoute } from "@tanstack/solid-router";import { useIntlayer } from "solid-intlayer";import { LocalizedLink } from "@/components/LocalizedLink";export const Route = createFileRoute("/{-$locale}/")({ component: RouteComponent,});function RouteComponent() { const content = useIntlayer("index-page"); return ( <main> <h1>{content.heroTitle}</h1> <p>{content.heroDesc}</p> <div> <LocalizedLink to="/">{content.navHome}</LocalizedLink> <LocalizedLink to="/about">{content.navAbout}</LocalizedLink> </div> </main> );}إذا كنت ترغب في استخدام المحتوى الخاص بك في خاصية من نوعstring، مثلalt،title،href،aria-label، إلخ، يجب عليك استدعاء قيمة الدالة، مثل:
htmlنسخ الكودنسخ الكود إلى الحافظة
<img src="{content.image.src.value}" alt="{content.image.value}" /><img src="{content.image.src.toString()}" alt="{content.image.toString()}" /><img src="{String(content.image.src)}" alt="{String(content.image)}" />
في Solid، يعيد
useIntlayerمحتوى تفاعلياً (على سبيل المثال،content). يمكنك الوصول إلى خصائصه مباشرة.لمعرفة المزيد حول خطاف
useIntlayer، راجع التوثيق.
الخطوة 10: إنشاء مكون لتبديل اللغة
أنشئ مكونًا للسماح للمستخدمين بتغيير اللغات:
نسخ الكود إلى الحافظة
import { useLocation } from "@tanstack/solid-router";import { getLocaleName, getPathWithoutLocale, getPrefix } from "intlayer";import { For } from "solid-js";import { useIntlayer, useLocale } from "solid-intlayer";import { LocalizedLink, type To } from "./LocalizedLink";export const LocaleSwitcher = () => { const content = useIntlayer("locale-switcher"); const location = useLocation(); const { availableLocales, locale, setLocale } = useLocale(); const pathWithoutLocale = () => getPathWithoutLocale(location().pathname); return ( <div class="flex flex-row gap-2"> <For each={availableLocales}> {(localeEl) => ( <LocalizedLink aria-current={localeEl === locale() ? "page" : undefined} onClick={() => setLocale(localeEl)} params={{ locale: getPrefix(localeEl).localePrefix }} to={pathWithoutLocale() as To} > {getLocaleName(localeEl)} </LocalizedLink> )} </For> </div> );};export default LocaleSwitcher;في ملفات Solid ، يكون
localeمنuseLocaleعبارة عن signal accessor. استخدمlocale()(مع القوسين) لقراءة قيمته الحالية بشكل تفاعلي.لمعرفة المزيد حول خطاف
useLocale، راجع التوثيق.
الخطوة 11: إدارة سمات HTML
كما رأيت في الخطوة 5، يمكنك إدارة سمات lang و dir لوسم html باستخدام useParams في المكون الجذري الخاص بك. يضمن ذلك تعيين السمات الصحيحة على كل من الخادم والعميل.
نسخ الكود إلى الحافظة
const RootComponent: ParentComponent = (props) => { const params = LocaleRoute.useParams(); const locale = params()?.locale ?? defaultLocale; return ( <html dir={getHTMLTextDir(locale)} lang={locale}> {/* ... */} </html> );};الخطوة 12: إضافة برمجية وسيطة (اختياري)
يمكنك أيضًا استخدام intlayerProxy لإضافة توجيه من جانب الخادم إلى تطبيقك. ستكتشف هذه الإضافة تلقائيًا اللغة الحالية بناءً على الرابط وتعيين ملف تعريف الارتباط المناسب للغة. إذا لم يتم تحديد لغة، فستحدد الإضافة اللغة الأكثر ملاءمة بناءً على تفضيلات لغة متصفح المستخدم. إذا لم يتم اكتشاف لغة، فسيتم إعادة التوجيه إلى اللغة الافتراضية.
لاحظ أنه لاستخدامintlayerProxyفي الإنتاج، تحتاج إلى نقل حزمةvite-intlayerمنdevDependenciesإلىdependencies.
نسخ الكود إلى الحافظة
import { tanstackStart } from "@tanstack/solid-start/plugin/vite";import solid from "vite-plugin-solid";import { nitro } from "nitro/vite";import { defineConfig } from "vite";import { intlayer, intlayerProxy } from "vite-intlayer";export default defineConfig({ plugins: [ intlayerProxy(), // يجب وضع الوكيل قبل الخادم إذا كنت تستخدم Nitro nitro(), intlayer(), tanstackStart({ router: { routeFileIgnorePattern: ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$", }, }), solid(), ],});الخطوة 13: تدويل العناوين (metadata) الخاصة بك (اختياري)
يمكنك أيضًا استخدام وظيفة getIntlayer للوصول إلى قواميس المحتوى الخاصة بك داخل محمل head للعناوين المدركة للغة:
نسخ الكود إلى الحافظة
import { createFileRoute } from "@tanstack/solid-router";import { getIntlayer } from "intlayer";export const Route = createFileRoute("/{-$locale}/")({ component: RouteComponent, head: ({ params }) => { const { locale } = params; const path = "/"; // The path for this route const metaContent = getIntlayer("app", locale); return { links: [ // Canonical link: Points to the current localized page { rel: "canonical", href: getLocalizedUrl(path, locale) }, // Hreflang: Tell Google about all localized versions ...localeMap(({ locale: mapLocale }) => ({ rel: "alternate", hrefLang: mapLocale, href: getLocalizedUrl(path, mapLocale), })), // x-default: For users in unmatched languages // Define the default fallback locale (usually your primary language) { rel: "alternate", hrefLang: "x-default", href: getLocalizedUrl(path, defaultLocale), }, ], meta: [ { title: metaContent.title }, { name: "description", content: metaContent.meta.description }, ], }; },});الخطوة 14: الحصول على اللغة في إجراءات الخادم الخاص بك (اختياري)
قد ترغب في الوصول إلى اللغة الحالية من داخل إجراءات الخادم (server actions) أو نقاط نهاية API.
يمكنك القيام بذلك باستخدام مساعد getLocale من intlayer.
إليك مثال باستخدام وظائف الخادم في TanStack Start:
نسخ الكود إلى الحافظة
import { createServerFn } from "@tanstack/solid-start";import { getRequestHeader, getRequestHeaders,} from "@tanstack/solid-start/server";import { getCookie, getIntlayer, getLocale } from "intlayer";export const getLocaleServer = createServerFn().handler(async () => { const locale = await getLocale({ // الحصول على ملف تعريف الارتباط من الطلب (افتراضيًا: 'INTLAYER_LOCALE') getCookie: (name) => { const cookieString = getRequestHeader("cookie"); return getCookie(name, cookieString); }, // الحصول على الترويسة من الطلب (افتراضيًا: 'x-intlayer-locale') // تراجع باستخدام التفاضل Accept-Language getHeader: (name) => getRequestHeader(name), }); // استرجاع بعض المحتوى باستخدام getIntlayer() const content = getIntlayer("app", locale); return { locale, content };});الخطوة 15: إدارة الصفحات غير الموجودة (404) (اختياري)
عندما يزور المستخدم صفحة غير موجودة ، يمكنك عرض صفحة 404 مخصصة ويمكن أن تؤثر بادئة اللغة على كيفية تشغيل الصفحة غير الموجودة.
فهم معالجة 404 في TanStack Router مع بادئات اللغة
في TanStack Router ، تتطلب معالجة صفحات 404 مع المسارات المترجمة نهجًا متعدد المستويات:
- مسار 404 مخصص: مسار محدد لعرض واجهة مستخدم 404
- التحقق على مستوى المسار: يتحقق من بادئات اللغة ويعيد توجيه البادئات غير الصالحة إلى 404
- مسار التقاط الكل (Catch-all): يلتقط أي مسارات غير متطابقة داخل جزء اللغة
نسخ الكود إلى الحافظة
import { createFileRoute } from "@tanstack/solid-router";// ينشئ هذا مسار /[locale]/404 مخصصًا// يتم استخدامه كمسار مباشر ويتم استيراده كمكون في ملفات أخرىexport const Route = createFileRoute("/{-$locale}/404")({ component: NotFoundComponent,});// يتم تصديره بشكل منفصل بحيث يمكن إعادة استخدامه في notFoundComponent ومسارات التقاط الكلexport function NotFoundComponent() { return ( <div> <h1>404</h1> </div> );}نسخ الكود إلى الحافظة
import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";import { validatePrefix } from "intlayer";import { NotFoundComponent } from "./404";export const Route = createFileRoute("/{-$locale}")({ // يتم تشغيل beforeLoad قبل عرض المسار (كل من الخادم والعميل) // إنه المكان المثالي للتحقق من بادئة اللغة beforeLoad: ({ params }) => { const localeParam = params.locale; // يتحقق validatePrefix مما إذا كانت اللغة صالحة وفقًا لإعدادات intlayer الخاصة بك const { isValid, localePrefix } = validatePrefix(localeParam); if (!isValid) { // بادئة لغة غير صالحة - إعادة توجيه إلى صفحة 404 مع بادئة لغة صالحة throw redirect({ to: "/{-$locale}/404", params: { locale: localePrefix }, }); } }, component: Outlet, // يتم استدعاء notFoundComponent عندما لا يكون المسار الفرعي موجودًا // مثال: /en/صفحة-غير-موجودة يشغل هذا داخل تخطيط /en notFoundComponent: NotFoundComponent,});نسخ الكود إلى الحافظة
import { createFileRoute } from "@tanstack/solid-router";import { NotFoundComponent } from "./404";// يطابق مسار $ (الكل) أي مسار لا يطابق المسارات الأخرى// مثال: /en/بعض/المسارات/العميقة/غير/الصالحة// يضمن هذا أن تعرض جميع المسارات غير المتطابقة داخل اللغة صفحة 404// بدون هذا ، قد تعرض المسارات العميقة غير المتطابقة صفحة فارغة أو خطأexport const Route = createFileRoute("/{-$locale}/$")({ component: NotFoundComponent,});(اختياري) الخطوة 16: استخراج المحتوى من مكوناتك
إذا كان لديك قاعدة أكواد حالية ، فقد يستغرق تحويل آلاف الملفات وقتًا طويلاً.
لتسهيل هذه العملية ، يقترح Intlayer مترجمًا (compiler) / مستخرجًا (extractor) لتحويل مكوناتك واستخراج المحتوى.
لإعداده ، يمكنك إضافة قسم compiler في ملف intlayer.config.ts الخاص بك:
نسخ الكود إلى الحافظة
import { type IntlayerConfig } from "intlayer";
const config: IntlayerConfig = {
// ... بقية إعداداتك
compiler: {
/**
* يشير إلى ما إذا كان يجب تمكين المترجم.
*/
enabled: true,
/**
* يحدد مسار ملفات المخرجات
*/
output: ({ fileName, extension }) => `./${fileName}${extension}`,
/**
* يشير إلى ما إذا كان يجب حفظ المكونات بعد تحويلها.
*
* - إذا كان `true` ، فسيقوم المترجم بإعادة كتابة ملف المكون على القرص. وبالتالي ، سيكون التحويل دائمًا ، وسيقوم المترجم بتجاوز التحويل للعملية التالية. بهذه الطريقة ، يمكن للمترجم تحويل التطبيق ومن ثم يمكن إزالته.
*
* - إذا كان `false` ، فسيقوم المترجم بحقن استدعاء وظيفة `useIntlayer()` في الكود فقط في مخرجات البناء ، مع الحفاظ على قاعدة الأكواد الأساسية كما هي. سيتم إجراء التحويل في الذاكرة فقط.
*/
saveComponents: false,
/**
* بادئة مفتاح القاموس
*/
dictionaryKeyPrefix: "",
},
};
export default config;قم بتشغيل المستخرج لتحويل مكوناتك واستخراج المحتوى
نسخ الكود إلى الحافظة
npx intlayer extractالخطوة 17: إعداد TypeScript (اختياري)
يستخدم Intlayer تقوية الوحدات (module augmentation) للاستفادة من ميزات TypeScript وجعل قاعدة الأكواد الخاصة بك أكثر قوة.
تأكد من أن إعدادات TypeScript الخاصة بك تتضمن الأنواع المنشأة تلقائيًا:
نسخ الكود إلى الحافظة
{ // ... إعداداتك الحالية include: [ // ... التضمينات الحالية ".intlayer/**/*.ts", // تضمين الأنواع المنشأة تلقائيًا ],}إعدادات Git
يوصى بتجاهل الملفات التي تم إنشاؤها بواسطة Intlayer. يتيح لك ذلك تجنب إرسالها إلى مستودع Git الخاص بك.
للقيام بذلك ، يمكنك إضافة التعليمات التالية إلى ملف .gitignore الخاص بك:
نسخ الكود إلى الحافظة
# تجاهل الملفات التي تم إنشاؤها بواسطة Intlayer.intlayerإضافة VS Code
لتحسين تجربة التطوير الخاصة بك مع Intlayer ، يمكنك تثبيت إضافة Intlayer VS Code الرسمية.
توفر هذه الإضافة:
- الإكمال التلقائي لمفاتيح الترجمة.
- اكتشاف الأخطاء في الوقت الفعلي للترجمات المفقودة.
- معاينة مضمنة للمحتوى المترجم.
- إجراءات سريعة لإنشاء وتحديث الترجمات بسهولة.
لمزيد من التفاصيل حول كيفية استخدام الإضافة ، راجع توثيق إضافة Intlayer VS Code.
المضي قدمًا
للمضي قدمًا ، يمكنك تنفيذ المحرر المرئي أو إخراج محتواك باستخدام نظام إدارة المحتوى (CMS).