Localization & Globalization
This article describes how to localize UI elements and contents of your survey.
Localize UI Elements
Available Languages
Survey UI is translated into over 50 languages. We ship translated strings as dictionary files. They are supported by the community and may contain untranslated strings. To fill the gap, these strings are translated by Azure AI Translator by Microsoft. Each dictionary file contains a log of machine translations at the end. You can use it to find individual machine-translated strings and revise them if required. Delete revised strings from the log to exclude them from machine translation.
You can also create new dictionaries for unsupported languages. Use English as a base dictionary: copy the file, replace English translations in it, and submit a pull request with the resulting file to the survey-library repository.
Enable Localization and Switch Between Locales
The localization engine that works with dictionaries is available as a separate script/module. This script/module imports dictionaries for all languages. Reference this script in the <head>
tag of your page or import this module into the component that renders your survey:
<script src="https://unpkg.com/survey-core/survey.i18n.min.js"></script>
import "survey-core/survey.i18n";
Since SurveyJS v1.9.112, you may reference or import only the languages you need, as shown below:
<script src="https://unpkg.com/survey-core/i18n/french.js"></script>
<script src="https://unpkg.com/survey-core/i18n/german.js"></script>
<script src="https://unpkg.com/survey-core/i18n/italian.js"></script>
import "survey-core/i18n/french";
import "survey-core/i18n/german";
import "survey-core/i18n/italian";
The default language for UI elements is English. To select another language, use SurveyModel
's locale
property. For example, the following code translates the survey UI to French:
import { Model } from "survey-core";
import "survey-core/i18n/french";
const surveyJson = { ... };
const survey = new Model(surveyJson);
survey.locale = "fr";
Override Individual Translations
If you want to change individual translation strings, get an object with all translation strings for a specific locale and override the required properties in this object. Refer to the English dictionary for a full list of available properties.
import { getLocaleStrings } from 'survey-core';
// Get the English locale. To get the default locale, pass an empty string.
const engLocale = getLocaleStrings("en");
// Override individual translations
engLocale.pagePrevText = "Back";
engLocale.pageNextText = "Forward";
You can also create a custom locale to apply multiple translations in a batch. The following code shows how to do it in a separate TypeScript translation file (dictionary):
// custom-locale.ts
import { setupLocale } from 'survey-core';
const customLocaleStrings = {
pagePrevText: "Back",
pageNextText: "Forward",
completeText: "Send"
};
setupLocale({
localeCode: "customlocale", // A short code used as a locale identifier (for example, "en", "de", "fr")
strings: customLocaleStrings, // An array with custom translations
nativeName: "Custom Locale", // The locale name in native language
englishName: "Custom Locale", // The locale name in English
rtl: false // A flag that indicates whether the language is right-to-left
});
import './localization/custom-locale.ts'
// ...
// Activate the custom locale
survey.locale = "customlocale";
If any translation strings or other settings are missing in your custom locale, they will be taken from the English locale. You can specify the defaultLocale
property to use another fallback locale:
import { Model, surveyLocalization } from "survey-core";
import "survey-core/i18n/french";
surveyLocalization.defaultLocale = "fr";
const surveyJson = { ... };
const survey = new Model(surveyJson);
Localize Survey Contents
You can localize questions, choices, columns, rows, and other survey texts right in the survey JSON schema. Normally, properties that specify survey texts accept string values, like the title
property does in the code below:
const surveyJson = {
"elements": [{
"type": "text",
"name": "firstname"
"title": "Enter your first name"
}]
};
To localize survey texts, specify the properties with objects instead of string values. Each object field should indicate a locale and the field value—a translation for this locale:
const surveyJson = {
"elements": [{
"type": "text",
"name": "firstname"
"title": {
"default": "Enter your first name",
"de": "Geben Sie Ihren Vornamen ein",
"fr": "Entrez votre prénom"
}
}]
};
You do not have to specify translations for all locales. If a translation is missing for the current locale, the survey takes the translation from the default
field.
To apply your translations, set the current locale:
survey.locale = "de";
Localize choicesByUrl
Checkbox, Dropdown, and Radiogroup questions can load choices from a RESTful service if you specify the choicesByUrl
property. To localize choices, ensure that the RESTful service returns them in the following format:
[{
"choiceId": 1,
"choiceTitle": {
"en": "En 1",
"de": "De 1"
}
}, {
"choiceId": 2,
"choiceTitle": {
"en": "En 2",
"de": "De 2"
}
},
// ...
]