UG9wcGluczo1MDA=
.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="b1d71107423edcaecb40a1b10bd74c55"] { border-radius: 20px;padding: 40px 0px 40px 0px;margin-top: 48px;border: 1px solid rgba( 205, 189, 226, 0.2 ); } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="0ed16b4de24cd28133d3d3fe7481e02d"] { padding: 0px 40px 0px 40px;margin-top: 32px; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="253f44d9ed8f8d361966c5830ccc9c19"] { background: url('https://ptc.wpml.org/wp-content/uploads/2024/10/otgs-ico-infinity.svg') left center no-repeat;background-size: 24px auto;min-height: 24px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="ed6e773a6b204fb6fc42c90fcca21286"] { background: url('https://ptc.wpml.org/wp-content/uploads/2024/10/otgs-ico-user.svg') left center no-repeat;background-size: 24px auto;min-height: 24px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="4f1446dc51654f765f8bd4ab5651999b"] { background: url('https://ptc.wpml.org/wp-content/uploads/2024/02/lightning.svg') left center no-repeat;background-size: 24px auto;min-height: 24px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="c8ef083553c3762090f61d6313ba78cb"] { padding: 0px 40px 32px 40px;margin-top: 32px;border-bottom: 1px solid rgba( 205, 189, 226, 0.2 ); } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] { grid-template-columns: minmax(0, 0.045fr) minmax(0, 0.955fr);grid-column-gap: 16px;grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="6606b0897e22c4d46d293612994cc267"] { background: url('https://ptc.wpml.org/wp-content/uploads/2024/02/ai.svg') left center no-repeat;background-size: 24px auto;min-height: 24px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="0e18fb531c5803c5c9a698905cb2308a"] { padding: 0px 40px 32px 40px;border-bottom: 1px solid rgba( 205, 189, 226, 0.2 ); } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] { grid-template-columns: minmax(0, 0.045fr) minmax(0, 0.955fr);grid-column-gap: 16px;grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .tb-heading[data-toolset-blocks-heading="ceef69ea7c64efc1565beb497e2aafac"]  { padding-top: 0px;padding-bottom: 0px;margin-top: 0px;margin-bottom: 0px; }  .tb-heading[data-toolset-blocks-heading="61d1559a6c8b67b1696751b66fb53e46"]  { font-size: 18px;font-family: Poppins;font-weight: 500;color: rgba( 255, 255, 255, 1 );padding-top: 0px;padding-bottom: 0px;margin-top: 0px;margin-bottom: 12px; }  .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="e8e92e51f21e894437d303a73cd2949c"] { padding-top: 4px;display: flex; } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="079b3af6eafa064ef70b4deeb98bfd21"] { background: url('https://ptc.wpml.org/wp-content/uploads/2024/02/refresh.svg') left center no-repeat;background-size: 24px auto;min-height: 24px;display:ms-flexbox !important;display:flex !important;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center; } .tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom} .tb-image[data-toolset-blocks-image="41b3417669d3a4a68d84c628c9229507"] { max-width: 100%; } .tb-image[data-toolset-blocks-image="41b3417669d3a4a68d84c628c9229507"] img { border-radius: 10px;background-color: rgba( 22, 26, 27, 1 );padding: 24px; } .tb-image[data-toolset-blocks-image="41b3417669d3a4a68d84c628c9229507"]:hover img { transform: scale(1.02); } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] { margin-bottom: 24px;grid-template-columns: minmax(0, 0.115fr) minmax(0, 0.885fr);grid-column-gap: 16px;grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } h5.tb-heading[data-toolset-blocks-heading="fb89dc2c3ee6e20870a749469e0fa383"]  { color: rgba( 255, 255, 255, 1 );padding-top: 0px;padding-bottom: 0px;margin-top: 0px;margin-bottom: 0px; }  .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="f586ff7bfe1d7317c63162ec7b7039ed"] { display: flex; } .tb-heading[data-toolset-blocks-heading="154e3ff8f60babef715ff5662fc3455b"]  { font-family: Poppins;font-weight: 500;color: rgba( 22, 26, 27, 1 );text-align: center;background-color: rgba( 205, 189, 226, 1 );border-radius: 50px;padding: 8px 16px 8px 16px;margin-top: 0px;margin-bottom: 0px; }  @media only screen and (max-width: 781px) { .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] { grid-template-columns: minmax(0, 0.04fr) minmax(0, 0.96fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] { grid-template-columns: minmax(0, 0.04fr) minmax(0, 0.96fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 }   .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="e8e92e51f21e894437d303a73cd2949c"] { display: flex; } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] { grid-template-columns: minmax(0, 0.13fr) minmax(0, 0.87fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 }  .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="f586ff7bfe1d7317c63162ec7b7039ed"] { display: flex; } .tb-heading[data-toolset-blocks-heading="154e3ff8f60babef715ff5662fc3455b"]  { text-align: center; }   } @media only screen and (max-width: 599px) { .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="b1d71107423edcaecb40a1b10bd74c55"] { border-radius: 0;padding: 0px;border: 0px solid rgba( 0, 0, 0, 1 ); } .tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="0ed16b4de24cd28133d3d3fe7481e02d"] { padding-right: 0px;padding-left: 0px; } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="c8ef083553c3762090f61d6313ba78cb"] { padding-right: 0px;padding-left: 0px; } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] { grid-template-columns: minmax(0, 0.08fr) minmax(0, 0.92fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="d0d7ad2fc444fc151a00c50a434b8ace"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-container .tb-container-inner{width:100%;margin:0 auto} .wp-block-toolset-blocks-container.tb-container[data-toolset-blocks-container="0e18fb531c5803c5c9a698905cb2308a"] { padding-right: 0px;padding-left: 0px; } .tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] { grid-template-columns: minmax(0, 0.08fr) minmax(0, 0.92fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="df7c843f555276dac5085953f36128c8"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 }   .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="e8e92e51f21e894437d303a73cd2949c"] { display: flex; } .tb-container .tb-container-inner{width:100%;margin:0 auto}.tb-image{position:relative;transition:transform 0.25s ease}.wp-block-image .tb-image.aligncenter{margin-left:auto;margin-right:auto}.tb-image img{max-width:100%;height:auto;width:auto;transition:transform 0.25s ease}.tb-image .tb-image-caption-fit-to-image{display:table}.tb-image .tb-image-caption-fit-to-image .tb-image-caption{display:table-caption;caption-side:bottom}.tb-grid,.tb-grid>.block-editor-inner-blocks>.block-editor-block-list__layout{display:grid;grid-row-gap:25px;grid-column-gap:25px}.tb-grid-item{background:#d38a03;padding:30px}.tb-grid-column{flex-wrap:wrap}.tb-grid-column>*{width:100%}.tb-grid-column.tb-grid-align-top{width:100%;display:flex;align-content:flex-start}.tb-grid-column.tb-grid-align-center{width:100%;display:flex;align-content:center}.tb-grid-column.tb-grid-align-bottom{width:100%;display:flex;align-content:flex-end} .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] { grid-template-columns: minmax(0, 0.24fr) minmax(0, 0.76fr);grid-auto-flow: row } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] > .tb-grid-column:nth-of-type(2n + 1) { grid-column: 1 } .wp-block-toolset-blocks-grid.tb-grid[data-toolset-blocks-grid="f7025adec5f9859179ca9ed458a06f28"] > .tb-grid-column:nth-of-type(2n + 2) { grid-column: 2 }  .wp-block-toolset-blocks-grid-column.tb-grid-column[data-toolset-blocks-grid-column="f586ff7bfe1d7317c63162ec7b7039ed"] { display: flex; } .tb-heading[data-toolset-blocks-heading="154e3ff8f60babef715ff5662fc3455b"]  { text-align: center; }   } 
Learn how to prepare JSON files for translation and easily translate them using PTC (Private Translation Cloud).
JSON (JavaScript Object Notation) files store key content for user interfaces in frameworks like React, Vue.js, Angular, React Native, Swift (iOS), and Kotlin (Android). This content includes labels, error messages, and notifications. To support multiple languages in your software, you need to translate this text.
PTC (Private Translation Cloud) makes translating JSON files fast and accurate. With AI that creates Better Than Human Translation and Git integration, PTC ensures your translations stay up to date with your codebase.
In this tutorial, you’ll learn how to structure JSON files for translation and how to use PTC to translate the content in your JSON files, allowing your software to support multiple languages.
How JSON Files Store and Display Text
Before translating the text in your JSON files, it’s important to understand how these files store content and why they’re a good choice for software localization.
JSON is a lightweight and flexible format, which makes it a popular option for storing and exchanging data in software projects. Its structure allows both humans and machines to easily read and manage content, making it ideal for handling translations.
JSON files contain key-value pairs, with each key representing a label and the value holding the content you want to display. For example:
{
"welcomeMessage": "Welcome to our site",
"contactButton": "Contact Us"
}
Here, "welcomeMessage"
serves as the key, and "Welcome to our site"
represents the value (the text users see).
Some frameworks or libraries may use more complex formats. For example, WordPress uses a JED format, which is generated from .po files. However, in most cases, JSON files rely on key-value pairs to handle translations.
While JSON files serve many purposes, we’ll focus on how to use them for storing translation values and how to easily translate these files into multiple languages.
Preparing a JSON File for Translation
To make your software multilingual, you need to organize your JSON files for translation. These files act as resource files that store all user-facing text, such as headings, buttons, and error messages.
In most JavaScript frameworks like React, Vue.js, and Angular, you need to create and manage JSON resource files manually. Libraries such as i18next (for React) and vue-i18n (for Vue.js) help automate parts of this process.
To create clear JSON files that both translators and tools can work with:
Start by going through all the text you want to display to users and include it in your JSON file as key-value pairs. This includes headings, button labels, error messages, and tooltips. Remove any text that isn’t meant for translation, such as developer comments.
Make your keys as descriptive as possible so that both translators (or PTC’s AI translation) and developers can easily understand them. Avoid generic names like "button1"
or "text2"
. Instead, use meaningful keys, such as "contactButton"
or "welcomeMessage”
. For example, an English resource file might look like this:
{
"welcomeMessage": "Welcome to our site",
"contactButton": "Contact Us",
"errorMessage": "An error occurred. Please try again."
}
For larger or more complex files, grouping related content into sections using nested structures makes them more organized and easier to maintain. For example:
{
"homepage": {
"title": "Welcome to our Website",
"description": "Discover our products and services"
},
"footer": {
"contact": {
"phone": "Phone",
"email": "Email"
},
"legal": {
"terms": "Terms of Service",
"privacy": "Privacy Policy"
}
}
}
You’ll need to use placeholders if your text contains changing elements, like a user’s name or a number. Placeholders act as markers for dynamic content that will change based on the user or context.
Example with placeholder:
{ "welcomeMessage": "Hello, {userName}!",
"dateMessage": "Today is {currentDate}."
}
In this example, {userName}
and {currentDate}
serve as placeholders. Translators – both human and automatic – recognize these placeholders and leave them untranslated, focusing only on the text around them. Once translated, the placeholders stay in place and display the correct values when your software runs.
Of course, the placeholder syntax varies depending on the library or configuration you’re using. The format shown here offers just one example, and your project might use a different placeholder structure based on its setup.
For larger JSON files, grouping related strings into sections makes translation easier and more efficient. By organizing similar content—such as navigation labels, form messages, or error notifications—into categories, you provide valuable context. This makes it easier for both translation tools and human translators to understand the purpose of each string and deliver more accurate translations.
Example:
{
"navigation": {
"home": "Home",
"about": "About Us"
},
"form": {
"submitButton": "Submit",
"resetButton": "Reset"
}
}
Translate the JSON File
Now that you’ve prepared your JSON file for translation, you can quickly and easily translate it using PTC (Private Translation Cloud) .
With PTC, you get:
AI and machine learning that provides Better Than Human Translation
Git integration to keep your translations up to date with your codebase
A simple, developer-friendly process
To translate your JSON file into multiple languages, you can use PTC’s Free resource files translation tool. It’s designed by developers to be fast, reliable, and free.
To use Free resource files translation, just upload your source file, choose the languages you want to translate into, and wait for PTC to automatically translate the text.
In minutes, PTC delivers downloadable high-quality translations for your JSON file. As shown in the example below, PTC keeps labels in the source language ( English ) and translates values into the target language ( Spanish ).
The original JSON resource file in English and the Spanish translations generated by PTC
Integrate JSON File Translation Directly into Your Git Flow
In this tutorial, you’ve learned how to prepare your JSON files for translation by structuring key-value pairs, using placeholders for dynamic content, and organizing related text into groups. You’ve also discovered how to translate JSON files using PTC’s Free resource files translation tool.
Instead of having to upload your JSON files every time there’s new text, you can integrate PTC’s translation process directly into your Git flow. The full PTC integration offers: