AngularJS ng-repeat 从数组填充网格

AngularJS ng-repeat to populate grid from array

提前感谢阅读。我正在尝试利用 angular 的 ng-repeat 将对象从数组渲染到 Nx3 Table。为了举例,让我们考虑一个 3x3 table.

这里是数组的简化示例:

objects = [{"text": "One, One"},{"text": "One, Two"},{"text": "One, Three"},
           {"text": "Two, One"},{"text": "Two, Two"},{"text": "Two, Three"},
           {"text": "Three, One"},{"text": "Three, Two"},{"text": "Three, Three"}];

"text" 字段描述每个元素在 3x3 网格矩阵中应出现的位置。我想在 objects 上使用 ng-repeat 生成如下所示的 html:

<table>
  <tr>
    <td>One, One</td>
    <td>One, Two</td>
    <td>One, Three</td>
  </tr>
  <tr>
    <td>Two, One</td>
    <td>Two, Two</td>
    <td>Two, Three</td>
  </tr>
  <tr>
    <td>Three, One</td>
    <td>Three, Two</td>
    <td>Three, Three</td>
  </tr>
</table>

有没有什么方法可以实现这一点而不需要将数组分成每行的单独数组?

最好的方法是在控制器中更改您的视图模型并将其绑定到 ng-repeat(但您已经说过您不想这样做)。如果您打算采用该路线,您还可以查看用户 @m59 answer,他在其中创建了一个可重复使用的过滤器来执行此操作。然而,这只是一个简单的答案,利用内置过滤器的可配置评估表达式,我们可以在其中 return truthy/falsy 值来确定它们是否需要重复。这最终具有不需要创建 2 个 ng-repeat 块的唯一优势(但这并不是那么糟糕)。因此,在您的控制器中,在作用域上添加一个函数,

$scope.getFiltered= function(obj, idx){
   //Set a property on the item being repeated with its actual index
   //return true only for every 1st item in 3 items
    return !((obj._index = idx) % 3); 
}

并在您看来应用过滤器:

  <tr ng-repeat="obj in objects | filter:getFiltered">
    <!-- Current item, i.e first of every third item -->
    <td>{{obj.text}}</td> 
    <!-- based on the _index property display the next 2 items (which have been already filtered out) -->
    <td>{{objects[obj._index+1].text}}</td>
    <td>{{objects[obj._index+2].text}}</td>
  </tr>

Plnkr

我想做同样的事情。

将数组转换为矩阵/网格

我有一个数组,我想将其转换为列大小为 4 的 grid/matrix。以下实现对我有用。您可以在嵌套的 ng-repeat

中根据需要使用两个计数器:row 和 col

在我的例子中,列数是 3。但是你可以在任何地方用一个变量替换那个 3。 h.seats 是我的 objects 数组,我想打印 X 或 - 基于该数组中元素的值

<div class="table-responsive">
    <table class="table table-bordered">
        <thead>
            <tr>
                <th ng-repeat="n in [].constructor(3 + 1) track by $index">{{$index}}</th>
            </tr>
        </thead>
        <tbody>
            <tr ng-repeat="(row, y) in getNumber(h.seats.length, 3) track by $index">
                <td>{{row+1}}</td>
                <td class="text-primary"
                    ng-repeat="(col, t) in h.seats track by $index"
                    ng-if="col >= (row)*3 && col < (row+1)*3">
                        <span ng-show="t.status"> X </span> 
                        <span ng-show="!t.status"> - </span>
                </td>
            </tr>
        </tbody>
    </table>
</div>

<th ng-repeat="n in [].constructor(3 + 1) track by $index">{{$index}}</th> 打印列号位于顶部的 header 行。 getNumber(h.seats.length, 3) returns 我把那个 table 的行数如下

.controller('CustomViewController', function ($scope, Principal, $state) {

    $scope.getNumber = function(length, columns) {
        return new Array(parseInt(length / columns + 1, 10));   
    }

ng-if="col >= (row)*3 && col < (row+1)*3"是计算哪些元素应该放在该行中的重要逻辑。 输出如下所示

0  1  2  3 
1  e1 e2 e3 
2  e4 e5 e6 
3  e7 e8 

参考以下link了解行和列计数器如何使用的详细信息: https://whosebug.com/a/35566132/5076414