Prepare your app
locize can be used with any i18n framework. Even with no i18n framework at all, for example with the locizify script.
Below we will continue with i18next as i18n framework. If you're curious to know why we suggest i18next, have a look at this page.
To have multiple languages on your website or application with , follow the below steps. First install the dependencies, use the following npm package or use a script tag load umd, esm or cjs from unkpg or cdnjs.com CDN.
# npm
$ npm install i18next --save
# yarn
$ yarn add i18next
These lines of code give you a brief overview about localization in JavaScript can work and what functions are available in 18next . If you want to use the library for JavaScript production please refer to the detailed instructions of each framework in our resources. There is a much easier integration than with innerHTML.

Check out the i18n getting started guide on the i18next page.
import i18next from 'i18next';
i18next.init({
lng: 'en',
debug: true,
resources: {
en: {
translation: {
"key": "hello world"
}
}
}
}, (err, t) => {
// initialized and ready to go!
document.getElementById('output').innerHTML = i18next.t('key');
});
Then just use i18next-locize-backend as i18next backend.
import i18next from 'i18next';
import Backend from 'i18next-locize-backend';
i18next
.use(Backend)
.init({
// ...other options
backend: {
projectId: '[PROJECT_ID]',
apiKey: '[API_KEY]',
referenceLng: '[LNG]'
}
});
Choose your framework
For famous JavaScript frameworks locize is very easy to integrate through the JavaScript localization library i18next.
data:image/s3,"s3://crabby-images/7d1b9/7d1b95113521b2de6032acd8f2406b3cbc22d5bc" alt="Framework Card Image"
i18next can also be used on server side...
In this tutorial blog post you can check out how this works.
On this page you'll find also non i18next aproaches.
data:image/s3,"s3://crabby-images/88414/884143dec4505ba2c3d87ae786651741759158c6" alt="Framework Card Image"
Installation of i18next and angular-i18next package needed
Import I18NextModule to AppModule
Import I18NextModule.forRoot() to App Module
and setup provider with "init"
Use i18next pipe to translate key
To unleash the full power of angular-i18next check out this tutorial blog post about Angular localization.
data:image/s3,"s3://crabby-images/36607/3660766832aa054348e318754099ff6b855b30d4" alt="Framework Card Image"
Installation of i18next and i18next-vue
Initialize i18next
Initial setup with app.use(I18NextVue, {i18next})
Set up a view
For more detailed instructions on how to properly internationalize a Vue app, check out this tutorial blog post about Vue localization.
As an alternative to i18next-vue, you can try vue-i18n like described in this tutorial blog post.
data:image/s3,"s3://crabby-images/a650a/a650a5bdef507aa187fbec4e4325ce0b42129fa5" alt="Framework Card Image"
Installation of i18next package needed
Add react-i18next to expand the functionality
Add a new file i18n.js inside same directory as index.js
Translate the content with "hook", "HOC" or "render prop"
For more detailed instructions on how to properly internationalize a React app, check out this tutorial blog post about React localization.
Manual vs Automated
Step-by-step code
implementation (the manual way)
This process is based on how to implement multiple languages for a sample React app.
For more detailed instructions on how to properly internationalize your project, shown with the help of a React app example, check out this tutorial blog post: "How to properly internationalize a React application using i18next"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
data:image/s3,"s3://crabby-images/630ab/630ab68b4f358b19467a7a55bcd67556f10b7c7c" alt="Manual Info Item Icon"
But there is more....
Take a minute and read about automating this process with a smart translation management system below. For extensive projects using just a library may too inefficient.
Automate translation work
(the smart way)
Congratulations you have decided to read about a robotic way to switch the language for any type of software. So this is for you. It's awesome which functionalities you can unleash for a small amount of money. Watch our videos and admire what you get from only five USD per month.
Use the full power of the i18next library together with locize, a localization management platform by the founders of i18next, which can automate the translation workflow in the locize app.
The machine / generative AI translation feature enables every new content to get automatically translated into all other defined target languages (like Google Translate, Deepl, Open AI, Mistral AI).
Register for free & unlock everything for a 14 days trial period.
Frequently asked questions
JavaScript localization, also known as l10n, involves adapting the content of a JavaScript application (texts, graphics, sounds, etc.) to meet the linguistic and cultural preferences of specific regions or audiences. This process focuses on ensuring the content feels natural to the target market.
To make your JavaScript app multilingual:Choose an i18n framework like i18next.
Instrument your code with proper placeholders and translation keys.
Follow our detailed checklist for step-by-step guidance to implement multilingual capabilities in your app.
i18n, or internationalization, is the process of preparing a software product for different markets and languages. This involves adding support for multiple locales, languages, and regional formats to adapt your product to global users. Learn more about the i18n process in our complete guide.
To support multiple languages:Select a JavaScript framework (React, Angular, or Vue.js).
Install the i18next npm package.
Add the i18next.init code to your application.
Follow our detailed examples and read our article on website localization for more information.
i18next is a robust JavaScript library with: Rich features (e.g., splitting translations into multiple files, string interpolation, language detection plugins).
Maturity (widely used and battle-tested for various use cases).
Extensibility (compatible with modern frameworks like React, Angular, Vue.js, and more).
i18n (Internationalization): Prepares the software to handle multiple languages and regional differences. l10n (Localization): Adapts the content (text, visuals, etc.) for specific languages or regions.
Both processes work together to deliver a seamless global experience.
If you only need to switch languages in a small project, a JavaScript translation library like i18next or locizify is sufficient.For large-scale projects with multiple components and frequent updates, a comprehensive translation management solution like locize is more efficient.
Locize provides a powerful platform with:Continuous localization to sync updates automatically.
Tools like InContext Editing to preview translations in real-time.
Integration options (API, CLI, GitHub Actions) for seamless workflows.
Yes, Locize is compatible with all major JavaScript frameworks, including React, Angular, and Vue.js. It supports modern architectures and integrates effortlessly with your development environment.
To internationalize your JavaScript application effectively, start by identifying the specific environment you're working with, such as React, Angular, or Vue.js, to select the most suitable i18n solution. Determine if your project would benefit from a language detector to automatically adapt to user preferences. Decide whether to bundle translations with your app for simplicity or load them separately via HTTP for easier updates. To streamline the process, consider using a powerful translation management system like Locize, which helps maintain consistency and reduces manual effort. For detailed setup instructions, the i18next guide provides comprehensive insights beyond just JavaScript environments.