繁体   English   中英

基于嵌套数组中匹配值的 angularjs 过滤器

[英]angularjs filter based on matching values in nested array

这是我的代码。 请运行脚本以查看它是如何工作的:

 var app = angular.module('myApp', []); app.controller('listdata', function($scope, $http) { var data = [{ "name": "John", "queue": [{ "number": "456", "status": "Unavailable" }, { "number": "111", "status": "Unavailable" }, { "number": "201", "status": "Paused" }], "phone": "7411173737" }, { "name": "George", "queue": [{ "number": "111", "status": "Paused" }, { "number": "456", "status": "Unavailable" }], "phone": "8558855858" }, { "name": "Hilary", "queue": [{ "number": "456", "status": "Unavailable" }], "phone": "5454573737" }, { "name": "Edmond", "queue": [{ "number": "665", "status": "Unavailable" }], "phone": "7454543737" }]; $scope.a = []; $scope.users = []; for(i=0;i<data.length;i++){ for(j=0;j<data[i].queue.length;j++){ if(data[i].queue[j].number == 111 || data[i].queue[j].number == 456){ $scope.a.push(data[i]); } } } $scope.users = $scope.a; //console.log($scope.users); $scope.filter111 = function (user) { return (user.queue.find(({number}) => number === '111')); } $scope.filter456 = function (user) { return (user.queue.find(({number}) => number === '456')); } }); app.filter('unique', function() { return function(collection, keyname) { var output = [], keys = []; angular.forEach(collection, function(item) { var key = item[keyname]; if(keys.indexOf(key) === -1) { keys.push(key); output.push(item); } }); return output; }; });
 <script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.7.5/angular.min.js"></script> <div ng-app="myApp"> <label class="switch"> <input type="checkbox" ng-model="queue111">111 </label> <label class="switch"> <input type="checkbox" ng-model="queue456">456 </label> <label class="switch"> <input type="checkbox" ng-true-value='"Paused"' ng-false-value='' ng-model="paused">Paused </label> <div class="row" ng-controller="listdata"> <div ng-repeat="user in users|filter: queue111? filter111: ''|unique:'name'|filter: queue456? filter456: ''|filter: paused track by $index"> <p> {{user.name}} {{user.phone}}</p> </div> </div> </div>

从上面的代码中,我的数据数组包含具有用户姓名、电话号码和他所属的呼叫队列的对象。

我有四个呼叫队列,分别是 111,456,201 和 665。

一个用户可以在任意数量的呼叫队列中。 我已经过滤了控制器中的数据,以便它只显示属于前端队列 111 或队列 456 的用户。

因此,根据我的代码,用户 Edmond 属于队列 665,因此他的详细信息不会显示在前端。 其他 3 个用户属于 111、456 或两者,因此他们的详细信息显示在用户面板中。

然后过滤器 111 只显示属于队列 111 的那些用户。过滤器 456 将只显示属于队列 456 的那些用户。

现在,用户对每个队列都有一个状态。 状态可以是UnavailablePaused等。

我在前端有一个名为Paused的过滤器,如代码所示,这个过滤器应该只输出那些状态为 111 或 456 队列中暂停的用户。 如果用户的状态不是在 111 或 456 中暂停,则不应输出用户。

当我单击Paused过滤器时,它会显示名字 John 和 George。 这个输出实际上是错误的,因为我只想在 111 或 456 队列中显示状态为 Paused 的那些。 所以在输出中,George 的结果是正确的,因为他的状态是 Paused in the queue 456 但对于 John 来说输出是错误的,因为他没有在 queue 111 或 456 中暂停。他在队列 201 中暂停并且仍然被显示不是预期输出的 Paused 过滤器。

预期的输出是它应该只显示 George 的数据,因为他实际上属于两个队列之一(111 或 456),并且他的状态在我在前端显示的队列之一(111 或 456)中暂停单击暂停过滤器。 我该怎么做呢?

我通过在控制器中创建一个自定义函数来解决这个问题,如下所示:

$scope.pausedc = function (user) {
          return (user.queue.find(({number,status}) => number === '111' && status === 'Paused' || number === '456' && status === 'Paused'));
      }

和 html :

<label class="switch">
  <input type="checkbox"  ng-model="paused">Paused
</label>


<div class="row" ng-controller="listdata">

  <div ng-repeat="user in users| filter:paused? pausedc: '' track by $index">
    <p> {{user.name}} {{user.phone}}</p>
  </div>
</div>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM