如何将forEach映射到angularJS中的手风琴

时间:2017-06-29 23:41:40

标签: javascript angularjs foreach accordion

目前我正在尝试使用angularJS中的forEach方法映射2个对象,并以手风琴形式显示它们。我并没有真正得到我想要的结果......它并没有真正过滤或吐出我想要的正确数据。

这是我到目前为止所拥有的......

HTML:

<accordion ng-repeat="fee in fees">
  <accordion-group ng-if="fee.feeBag.length">
    <accordion-heading>
      {{fee.headingName}}
    </accordion-heading>
      <div class="feecode-height" ng-repeat="feeParameter in fee.feeBag">
        <div class="row">
          <div class="col-xs-1">{{feeParameter.name}}</div>
          <div class="col-xs-4">{{feeParameter.text}}</div>
          <div class="col-xs-2" >{{feeParameter.amount}}</div>
        </div>
      </div>
  </accordion-group>
</accordion>

控制器:

angular.forEach($scope.fees, function(value, key) {
  angular.forEach(value.feeBag, function(value2, key2) {
    if (value.feeBag[key2].name === $scope.otherFees.name) {
      value.feeBag[key2].text =  $scope.otherFees.text;
      value.feeBag[key2].amount = $scope.otherFees.amount;

      return value.feeBag[key2];            
    } else {
      // remove the ones that dont belong 
      // value.feeBag.splice(key, 1);
    }

  });
});

JSON值:

$scope.otherFees = [{'name': 1, 'text': 'ok', 'amount': 2}, {'name': 2, 'text': 'hello', 'amount': 3}, {'name': 3, 'text': 'cool', 'amount': 3}]

$scope.fees = [
  { 
    'headingName': 'firstHeader',
    'feeBag': [
      {'name': 1}
    ]
  }, 
  {
    'headingName': 'secondHeader',    
    'feeBag': [
      {'name': 2}
    ]
  },
  {
    'headingName': 'thirdHeader',    
    'feeBag': [
      {'name': 3}
    ]
  }
]

我只是有点卡在我应该去的地方......似乎我把它设置为正确的按标题名称对值进行分组并让各个​​组显示在行中。

感谢所有帮助:D

1 个答案:

答案 0 :(得分:1)

在里面添加另一个循环以检查$scope.otherFees项的每个值:

angular.forEach($scope.fees, function(value, key) {
    angular.forEach(value.feeBag, function(value2, key2) {
        angular.forEach($scope.otherFees, function(value3, key3){
        if (value.feeBag[key2].name === value3.name) {
          value.feeBag[key2].text =  value3.text;
          value.feeBag[key2].amount = value3.amount;

          return value.feeBag[key2];            
        } else {
          // remove the ones that dont belong 
          // value.feeBag.splice(key, 1);
        }
      })
    });
  });

查看jsFiddle。我已经更新了。我希望你能找到的是什么。