更新控制器变量的指令模板 - angularjs

时间:2014-09-01 10:33:58

标签: json angularjs angularjs-directive angularjs-scope angularjs-ng-repeat

我要做的是从$ http请求中获取一个JSON对象,在控制器内部请求,并构建一个指令,在网格中的JSON对象中显示多个对象。

问题在于,当对象到达时,我必须在指令的控制器中处理它才能在模板中使用它,因此,当JSON对象发生更改时,它不会反映在模板中。如何让指令知道对象的更改并强制它重新加载模板?

// The Directive code
amobile.directive('grid', function() {
return {
    restrict: 'E',
    scope: {
        break: '=break',
        source: '=source'
    },
    controller: function($scope) {
        var source = $scope.source;
        $scope.final_data = new Array(source.length);
        if(source){
            for(var j=0; j < source.length; ++j){
                var total = Math.ceil(source[j]['Division'].length / $scope.break);
                var data = new Array(total);
                for (var i = 0; i < total; ++i) {
                    data[i] = source[j]['Division'].slice(i * $scope.break, (i + 1) * $scope.break);
                }
                $scope.final_data[j] = data;
            }
        }

    },
    templateUrl:'directives/grid.tpl.html',
    replace: true
};
});

//The template
<div ng-repeat="data in final_data">
<div layout="vertical" layout-sm="horizontal" layout-padding class="" ng-repeat="row in data">
    <div class="" ng-repeat="item in row">
        <div flex style="width:100px">
            {{item.name}}
        </div>
    </div>
</div>

//index.html
<div ng-controller="DivisionsCtrl as div">
    <material-button ng-click="div.go()" class="material-theme-red">Button</material-button>
<div ng-if="div.data.floors">
  <gridy break="3" source="div.data.floors"/>
</div>

1 个答案:

答案 0 :(得分:0)

最简单的解决方案是使用手表

controller: function($scope) {
    processData = function () {
      var source = $scope.source;
      $scope.final_data = new Array(source.length);
      if(source){
        for(var j=0; j < source.length; ++j){
            var total = Math.ceil(source[j]['Division'].length / $scope.break);
            var data = new Array(total);
            for (var i = 0; i < total; ++i) {
                data[i] = source[j]['Division'].slice(i * $scope.break, (i + 1) * $scope.break);
            }
            $scope.final_data[j] = data;
        }
      }
    }
  $scope.$watch('div.data.floors', processData, true)

},