AngularJS and web application internationalization
Internationalization of web applications is ubiquitous and i show how can you make it in your application with AngularJS.
For example we have some *.json
files with our translations, something like this en_US.json
:
{
"en_US" : {
"HOME": "home",
"GREETINGS": "Hello, how are you?"
....
}
}
First of all we must to load our en_US.json
file and files with other translations and save it's content to the variable. I will load it in the initialization part of web application.
app.js
:
var Lang =
(function() {var json = null;
$.ajax({
'async': false,
'url': "/en_US.json",
success: function (data) {
json = JSON.parse(data);
}
});
return json;
})();
Now we can use Lang
variable everywhere. Let's create AngularJS
filter. We will transform content to necessary translation.
MyApplication.filter('translate', function (){
return function(input){
//
// Check necessary locale locale
//
// .....
//
// Change locale
//
for (var prop in Lang){
if (prop == input)
// return translation
return Lang[prop];
}
}
});
Now we can ease translate any content in our application. Use translate
filter in your templates like:
<div>{{ 'GREETINGS' | translate }}
<p>{{ 'HOME' | translate }}</p>
</div>
Written by 0xAX
Related protips
2 Responses
data:image/s3,"s3://crabby-images/097ab/097abd23cb7ba92cc8691a9cbf8adbd4cc8ef6e6" alt=""
angular-translate has a similar approach :)
In addition, angular-translate doesn't have a jQuery dependency.
Check it out right here: https://github.com/PascalPrecht/angular-translate
Website: http://pascalprecht.github.io/angular-translate/#/guide
data:image/s3,"s3://crabby-images/49014/49014f1bbca05516995adce51f1117cff0099828" alt=""
@pascalprecht It would be awesome if angular-translate could simply load a en_US.json language file instead of defining it in the config. Is that possible?
Have a fresh tip? Share with Coderwall community!
data:image/s3,"s3://crabby-images/df778/df7789b3b3e6116db56eab009e6bdf20f1194b1c" alt=""
data:image/s3,"s3://crabby-images/ef213/ef213e9472df479b0886bbe3542e15f611396ce5" alt=""