如何比较ng-repeat中的两个不同对象

时间:2016-03-29 22:21:30

标签: javascript angularjs angularjs-directive angularjs-ng-repeat

在ng-repeat中比较两个不同对象之间的相同性的最佳方法是什么,为什么angular.equals在这里对我不起作用:

<tr ng-repeat="row in ctrl.filteredItems" ng-class="{'active':angular.equals(row,ctrl.ngModel), 'focus': angular.equals(row,ctrl.focusedRow)}">
      <td ng-repeat="value in ctrl.sort(row) track by $index" class="text-center">
            {{value}}
      </td>
</tr>

如果当前行和来自控制器的预选行匹配,我想添加活动类。

1 个答案:

答案 0 :(得分:2)

在JS中编写一个函数,它将执行angular.equals(obj1,obj2)并使用此函数检查它是否处于活动状态?

HTML

<tr ng-repeat="row in ctrl.filteredItems" ng-class="{'active': checkEqualiy(row, ctrl.ngModel), 'focus': checkEquality(row,ctrl.focusedRow)}">
  <td ng-repeat="value in ctrl.sort(row) track by $index" class="text-center">
        {{value}}
  </td>
</tr>

JS

$scope.checkEquality= function(param1, param2){
   return angular.equals(param1, param2)
}