4

我正在使用 Angular 和 ng-repeat 以及Semantic UI Grid布局。

我正在尝试连续显示 5 列。当达到第五个项目时,创建一个新行。下面为数据中的每个项目创建一个新的行和列。我可以看到 ng-repeat 有一个索引属性,但不确定如何基本上说if mod 5 == 0输出一个新的行元素,否则只输出一个新列。

<div class="ui grid">
    <div class="row" ng-repeat="item in data.results">
        <div class="column">
            <div class="ui segment">
                {{item.original_title}}
            </div>
        </div>
    </div>
</div>

谢谢您的帮助

4

3 回答 3

4

在我看来,最干净和最可维护的方法是编写指令。在您的 HTML 中,您只需:

<grid source="data.results" break="5" />

在您的 JS 中,您将数据分解为控制器内的正确结构并使用模板输出:

    angular.module('yourApp', [])
    .directive('grid', function() {
      return {
          restrict: 'E',
          scope: {
            break: '=break',
            source: '=source'
          },
          controller: function($scope) {
            var total = Math.ceil($scope.source.length / $scope.break);
            $scope.data = new Array(total);
            for (var i = 0; i < total; ++i) {
              $scope.data[i] = $scope.source.slice(i * $scope.break, (i + 1) * $scope.break);
            }
          },
          template:
            '<div class="ui grid">' +
            '  <div class="row" ng-repeat="row in data">' +
            '    <div class="column" ng-repeat="item in row">' +
            '      <div class="ui segment">' +
            '        {{item.original_title}}' +
            '      </div>' +
            '    </div>' +
            '  </div>' +
            '</div>',
          replace: true
      };
  });
于 2013-11-18T11:00:47.240 回答
3

这是一种使用范围过滤器来解决此问题的方法。

我们计算您需要多少行(data.results.length/5),然后使用ng-repeat范围过滤器迭代该行数。

然后在每一行中,我们slice取出该行所需的列,并用另一个创建这些列ng-repeat

<div class="row" ng-repeat="n in [] | range:(data.results.length/5)+1">
    <span ng-repeat='item in data.results.slice($index*5,($index*5+5))'>
        <div class="column">
           <div class="ui segment">
              {{item.original_title}}
           </div>
        </div>
    </span>
</div>

和相关的范围过滤器(来自:http ://www.yearofmoo.com/2012/10/more-angularjs-magic-to-supercharge-your-webapp.html#more-about-loops ):

app.filter('range', function () {
  return function (input, total) {
    total = parseInt(total);
    for (var i = 0; i < total; i++) {
        input.push(i);
    }
    return input;
};

这是一个小提琴:http: //jsfiddle.net/BMrNs/1/

于 2013-11-17T21:06:43.017 回答
2

尝试将ng-switchArray.slice()这不是最有效的方法结合使用,但如果您没有任何方法来干预数据表示,这是我能想到的最好的方法。

<div class="ui grid">
    <div ng-repeat="item in data.results">
        <div ng-switch on="$index % 5">
            <div ng-switch-when="0" class="row">
                <div ng-repeat="e in data.results.slice($index, $index + 5)">
                      <div class="column">
                          <div class="ui segment">
                              {{e.original_title}}
                          </div>
                      </div>
                </div>
            </div>
        </div>
    </div>
</div>
于 2013-11-17T20:44:41.790 回答