فرمت های پیام محلی سازی

هر پسوند بین المللی حداقل یک فایل به نام messages.json دارد که رشته های محلی خاص را ارائه می دهد. این صفحه فرمت فایل های messages.json را توضیح می دهد. برای اطلاعات در مورد نحوه بین المللی سازی و بومی سازی، صفحه بین المللی سازی را ببینید.

خلاصه میدان

کد زیر فیلدهای پشتیبانی شده برای messages.json را نشان می دهد. فقط فیلدهای " نام " و "پیام" مورد نیاز است.

messages.json:

{
  "name": {
    "message": "Message text, with optional placeholders.",
    "description": "Translator-aimed description of the message.",
    "placeholders": {
      "placeholder_name": {
        "content": "A string to be placed within the message.",
        "example": "Translator-aimed example of the placeholder string."
      },
      ...
    }
  },
  ...
}

مثال

در اینجا یک فایل messages.json وجود دارد که سه پیام به نام‌های "prompt_for_name"، "hello" و "bye" را تعریف می‌کند:

messages.json:

{
  "prompt_for_name": {
    "message": "What's your name?",
    "description": "Ask for the user's name"
  },
  "hello": {
    "message": "Hello, $USER$",
    "description": "Greet the user",
    "placeholders": {
      "user": {
        "content": "$1",
        "example": "Cira"
      }
    }
  },
  "bye": {
    "message": "Goodbye, $USER$. Come back to $OUR_SITE$ soon!",
    "description": "Say goodbye to the user",
    "placeholders": {
      "our_site": {
        "content": "Example.com",
      },
      "user": {
        "content": "$1",
        "example": "Cira"
      }
    }
  }
}

جزئیات میدان

این بخش هر فیلدی را که می‌تواند در فایل messages.json ظاهر شود، توضیح می‌دهد. برای جزئیات در مورد نحوه استفاده از فایل پیام‌ها - به عنوان مثال، چه اتفاقی می‌افتد وقتی یک منطقه همه پیام‌ها را تعریف نمی‌کند - بین‌المللی را ببینید.

نام

در واقع، فیلدی به نام "نام" وجود ندارد. نام این فیلد نام پیام است—همان نامی که در __MSG__name___ یا getMessage("_name_") می بینید.

نام یک کلید حساس به حروف کوچک و بزرگ است که به شما امکان می دهد متن پیام محلی را بازیابی کنید. نام می تواند شامل کاراکترهای زیر باشد:

  • AZ
  • az
  • 0-9
  • _ (تاکید)
  • @

در اینجا سه ​​نمونه از نام ها که از بخش مثال گرفته شده اند آورده شده است:

messages.json:

"prompt_for_name": {
  ...
},
"hello": {
  ...
},
"bye": {
  ...
}

برای مثال‌های بیشتر استفاده از نام‌ها، صفحه بین‌المللی‌سازی را ببینید.

پیام

پیام ترجمه شده، به شکل رشته ای که می تواند حاوی متغیرهایی باشد. از $_placeholder_name_$ (بدون حساس به حروف کوچک) برای اشاره به یک مکان نگهدار خاص استفاده کنید. برای مثال، می‌توانید به یک مکان‌نما به نام «our_site» به‌عنوان $our_site$ ، $OUR_SITE$ ، یا $oUR_sITe$ مراجعه کنید.

در اینجا سه ​​نمونه از پیام‌ها از بخش مثال گرفته شده است:

messages.json:

"message": "What's your name?"
...
"message": "Hello, $USER$"
...
"message": "Goodbye, $USER$. Come back to $OUR_SITE$ soon!"

برای قرار دادن علامت دلار ( $ ) در رشته، استفاده کنید $$. For example, use the following code to specify the message Amount (in $):

messages.json:

"message": "Amount (in $$) "

اگرچه مکان‌نماهایی مانند $USER$ روش ترجیحی برای ارجاع به رشته‌های جایگزین هستند (رشته‌هایی که با استفاده از پارامتر جایگزینی i18n.getMessage مشخص شده‌اند)، می‌توانید مستقیماً به رشته‌های جایگزینی نیز در پیام مراجعه کنید. به عنوان مثال، پیام زیر به سه رشته جایگزین اول ارسال شده به getMessage() اشاره دارد:

messages.json:

"message": "Params: $1, $2, $3"

با وجود این مثال، توصیه می کنیم به جای رشته های $_n_ در پیام های خود از متغیرهایی استفاده کنید. به جای متغیرها به عنوان نام متغیرهای خوب فکر کنید. یک هفته پس از نوشتن کد، احتمالاً فراموش خواهید کرد که $1 به چه چیزی اشاره دارد، اما می‌دانید که متغیرهای شما به چه چیزی اشاره می‌کنند. برای اطلاعات بیشتر در مورد متغیرها و رشته های جایگزین، به بخش متغیرها مراجعه کنید.

توضیحات

اختیاری. شرحی از پیام، با هدف ارائه متن یا جزئیات برای کمک به مترجم در انجام بهترین ترجمه ممکن.

در اینجا سه ​​نمونه از توضیحات، برگرفته از بخش مثال آورده شده است:

messages.json:

"description": "Ask for the user's name"
...
"description": "Greet the user"
...
"description": "Say goodbye to the user"

نگهدارنده های مکان

اختیاری. یک یا چند رشته فرعی را برای استفاده در پیام تعریف می کند. در اینجا دو دلیل وجود دارد که ممکن است بخواهید از یک مکان نگهدار استفاده کنید:

  • برای تعریف متن برای بخشی از پیام خود که نباید ترجمه شود. مثال‌ها: کد HTML، نام‌های علامت تجاری، مشخص‌کننده‌های قالب‌بندی.
  • برای ارجاع به یک رشته جایگزین ارسال شده به getMessage() . مثال: $1 .

هر مکان دارای یک نام، یک آیتم "محتوا" و یک آیتم "مثال" اختیاری است. نام مکان‌نما به حروف بزرگ و کوچک حساس است و می‌تواند دارای همان نویسه‌هایی باشد که نام پیام وجود دارد.

مقدار مورد "content" رشته ای است که می تواند به رشته های جایگزینی اشاره داشته باشد که با استفاده از پارامتر جایگزینی روش i18n.getMessage مشخص شده اند. مقدار یک آیتم "محتوا" معمولا چیزی شبیه "Example.com" یا "$1" است. اگر به رشته جایگزینی مراجعه کنید که وجود ندارد، یک رشته خالی دریافت می کنید. جدول زیر نشان می دهد که چگونه رشته های $_n_ با رشته های مشخص شده توسط پارامتر جایگزینی مطابقت دارند.

پارامتر جایگزینی ارزش 1 دلار ارزش 2 دلار ارزش 3 دلار
userName مقدار userName "" ""
["Cira", "Kathy"] "Cira" "Kathy" ""

مورد "مثال" (اختیاری، اما به شدت توصیه می شود) با نشان دادن نحوه نمایش محتوا به کاربر نهایی به مترجمان کمک می کند. برای مثال، یک جای‌بان برای مقدار دلار باید مثالی مانند "$23.45" داشته باشد.

قطعه زیر که از بخش Example گرفته شده است، یک آیتم "placeholders" را نشان می دهد که شامل دو مکان نگهدار به نام های "our_site" و "user" است. مکان‌نمای "our_site" مورد "مثالی" ندارد زیرا مقدار آن از قسمت "محتوا" مشخص است.

messages.json:

"placeholders": {
  "our_site": {
    "content": "Example.com",
  },
  "user": {
    "content": "$1",
    "example": "Cira"
  }
}