AngularJS 1.x 国际化——Angular-translate例子

  1. 云栖社区>
  2. 博客>
  3. 正文

AngularJS 1.x 国际化——Angular-translate例子

桃子红了呐 2017-11-15 14:57:00 浏览1464
展开阅读全文

可运行代码如下:

 

复制代码
<!DOCTYPE html>
<html ng-app="MyApp">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script src="http://apps.bdimg.com/libs/angular.js/1.2.16/angular.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-translate/2.15.1/angular-translate.js"></script>
</head>
<body>
    <div>
        <h1>{{ 'Hello' | translate }}</h1>
        <span translate='what? A dog.'></span>
    </div>
    <script type="text/javascript">
    var app = angular.module("MyApp",['pascalprecht.translate']);

    app.config(['$translateProvider',function($translateProvider){
          $translateProvider.translations('en',{
            'Hello':'Hello',
            'what? A dog.':'what? A dog.'
        });

          $translateProvider.translations('zh',{
            'Hello':'你好',
            'what? A dog.':'神马?这是一只旺财!'
        });

          $translateProvider.preferredLanguage('zh');
    }]);
    </script>
</body>
</html>
复制代码

 

注意:使用translate的两种常见方式,

  1. Create a pipe that we can use to translate our words in the HTML view. Like this:
<!-- should display 'hola mundo' when translate to Spanish -->
<p>{{ 'hello world' | translate }}</p>
  1. Create a service that we can use to translate our words in JS / Typescript. Like this:
...
// should display 'hola mundo' when translated to Spanish
this.translatedText = this.translate.instant('hello world'); // this.translate is our translate service
...

第二种方式方便直接在ts文件中使用!不过翻译的东西依然是在
$translateProvider.translations
里!

参考:https://scotch.io/tutorials/simple-language-translation-in-angular-2-part-1

















本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/bonelee/p/6874803.html,如需转载请自行联系原作者



网友评论

登录后评论
0/500
评论