javascript - ionic : How to make Angular Translate js working with Search Filter when language changed?

标签 javascript angularjs ionic-framework angular-filters angular-translate

Solved the issue. Solution is edited in this question. Thank you "praszyk".

我无法让 Angular Translate 与 Search Filter 一起工作。当语言为英语时,列表项可以照常用英语搜索。但是当语言是孟加拉语时,这些项目仍然可以用英语搜索,但不能用孟加拉语搜索。有什么解决办法吗?

查看

<ion-list>
            <ion-item>
              <label class="item item-input">
                <i class="icon ion-search placeholder-icon"></i>
                <input type="text" ng-model="input.filterUser" placeholder="Search">
              </label>
            </ion-item>
              <ion-item class="item-avatar" ng-repeat="user in groups | filter:input.filterUser">
                <img src="{{user.avatar}}">           
                <h2>{{user.name | translate}}</h2>
                <p>{{user.fullname}}
                  {{user.email}}</p>       
              </ion-item>        
          </ion-list>

Controller

.controller('CreditCtrl', function($scope, $ionicConfig, $translate) {

  $scope.input = {};  
  $scope.groups = [
  {
  index: 1,
  index_start_at: 56,
  name:  "Bnd_Nilgiri",
  surname: "Hayes",
  fullname: "Grace Beatty",
  email: "francis@livingston.es",
  bool: false,
  avatar: "img/ionic.png"
  },
  {
  index: 2,
  index_start_at: 57,
  name: "Bnd_Nilachal",
  surname: "Shayes",
  fullname: "Srace Beatty",
  email: "shuvo@livingston.es",
  bool: false,
  avatar: "img/ionic.png"
  }
];



 angular.forEach($scope.groups, function(user, index){
      $translate(user.name, {user: user}).then(function(translated){
        $scope.groups[index].name = translated;
      });
    });

})

翻译提供者

.config(function($stateProvider, $urlRouterProvider, $ionicConfigProvider, $translateProvider) {

 $translateProvider.translations('en', {
    Bnd_Nilgiri : 'Nilgiri Tourspot',
    Bnd_Nilachal : 'Nilachal Tourspot',
    Bnd_Bogalake : 'Bogalake Tourspot',    
  });
  $translateProvider.translations('de', {
    // Bandarban Tour Spots

    Bnd_Nilgiri : 'নিলগিরি ট্যুর স্পট',
    Bnd_Nilachal : 'নিলাচল ট্যুর স্পট',
    Bnd_Bogalake : 'বগালেক ট্যুর স্পট',
  });
  $translateProvider.preferredLanguage('en');

最佳答案

那是因为你的| translate 过滤器在 Angular 过滤器之后应用。

唯一可能的解决方案是事先转换数组 groups。 在将其应用于 groups 变量之前,您需要在 Controller 中使用 $translate 服务:

var en_translations =  {
    Bnd_Nilgiri : 'Nilgiri Tourspot',
    Bnd_Nilachal : 'Nilachal Tourspot',
    Bnd_Bogalake : 'Bogalake Tourspot',    
}

var de_translations = {
    Bnd_Nilgiri : 'নিলগিরি ট্যুর স্পট',
    Bnd_Nilachal : 'নিলাচল ট্যুর স্পট',
    Bnd_Bogalake : 'বগালেক ট্যুর স্পট',
};


var app = angular.module('myApp', ['pascalprecht.translate']);

app.config(['$translateProvider', function ($translateProvider) {
  // add translation table
  $translateProvider
    .translations('en', en_translations)
    .translations('de', de_translations)
    .preferredLanguage('de');
}]);

app.controller('Ctrl', ['$scope', '$translate', function ($scope, $translate) {
  // expose translation via `$translate` service
  $scope.groups =  [
    {
      index: 1,
      index_start_at: 56,
      name:  "Bnd_Nilgiri",
      surname: "Hayes",
      fullname: "Grace Beatty",
      email: "francis@livingston.es",
      bool: false,
      avatar: "img/ionic.png"
    },
    {
      index: 2,
      index_start_at: 57,
      name: "Bnd_Nilachal",
      surname: "Shayes",
      fullname: "Srace Beatty",
      email: "shuvo@livingston.es",
      bool: false,
      avatar: "img/ionic.png"
    }
  ];
  angular.forEach($scope.groups, function(user, index){
    $translate(user.name, {user: user}).then(function(translated){
      $scope.groups[index].name = translated;
    });
  });

}]);

我没有测试代码,但这是我想象的滚动方式。 基本上 filter:input.filterUser 对尚未翻译的 $scope.groups 数组进行操作,因此您需要在 ng-repeat 之前翻译它> 发生。

编辑:我在这里做了一个 plunkr 来展示上面的代码: http://plnkr.co/edit/sVgUIlFxfs6pDsdR2ydQ

关于javascript - ionic : How to make Angular Translate js working with Search Filter when language changed?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32816336/

相关文章:

javascript - 如何在 NVD3 lineChart 中指定域 x 轴

javascript - 在 AngularJS 中加载异步数据

Angular 4 RequestOption 对象不可分配给 post 方法

angular - ng2-pdf-viewer 渲染大 PDF 的问题(超过 300 页)

javascript - 允许 div 随页面滚动而滚动,但仅在父 div 内

javascript - 选择第二个字

javascript - AngularJs 将 url 作为参数传递

javascript - 如何在嵌套级别不受限制的情况下显示对象的动态嵌套子数组对象

ionic-framework - ionic 中的 Braintree Drop-in 容器

javascript - 如何合并和打乱数组数组