我有一个JSON对象,表示如下:
{
"orders" : [
{
"ordernum" : "PRAAA000000177800601",
"buyer" : "Donna Heywood"
"parcels" : [
{
"upid" : "UPID567890123456",
"tpid" : "TPID789456789485"
},
{
"upid" : "UPID586905486090",
"tpid" : "TPID343454645455"
}
]
},
{
"ordernum" : "ORAAA000000367567345",
"buyer" : "Melanie Daniels"
"parcels" : [
{
"upid" : "UPID456547347776",
"tpid" : "TPID645896579688"
},
{
"upid" : "UPID768577673366",
"tpid" : "TPID784574333345"
}
]
}
]
}
我需要在第二级别上执行转发器,这是“upid”数字的列表。
我已经知道如何获得最高级别
<li ng-repeat="o in orders">{{o.ordernum}}</li>
但我不清楚顺序循环一个级别。例如,这是错误的:
<li ng-repeat="p in orders.parcels">{{p.upid}}</li>
我也知道如何嵌套转发器来实现这一点,但在这种情况下,我根本不需要显示顶层。
澄清
这里的目标是有一个列表,其中包含4个“upid”数字(每个包裹有2个,订单中有2个包裹)。
答案 0 :(得分:5)
您可以创建新阵列&#39; parcels&#39;比如下面的演示:
var app = angular.module('app', []);
app.controller('homeCtrl', function($scope) {
$scope.data = {
"orders": [{
"ordernum": "PRAAA000000177800601",
"buyer": "Donna Heywood",
"parcels": [{
"upid": "UPID567890123456",
"tpid": "TPID789456789485"
}, {
"upid": "UPID586905486090",
"tpid": "TPID343454645455"
}]
}, {
"ordernum": "ORAAA000000367567345",
"buyer": "Melanie Daniels",
"parcels": [{
"upid": "UPID456547347776",
"tpid": "TPID645896579688"
}, {
"upid": "UPID768577673366",
"tpid": "TPID784574333345"
}]
}]
};
$scope.parcels = [];
angular.forEach($scope.data.orders, function(order) {
angular.forEach(order.parcels, function(parcel) {
$scope.parcels.push(parcel)
})
})
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<div ng-app="app">
<div ng-controller="homeCtrl">
<ul>
<li ng-repeat="o in parcels">{{o.upid}}</li>
</ul>
</div>
</div>
&#13;
答案 1 :(得分:5)
实际上与@sylwester的答案相同。将其放入filter
的更好方法。您可以通过传递propertyName参数来重用它。
在您的情况下,我们通过了parcels
<强> JS 强>
myApp.filter('createarray', function () {
return function (value, propertyName) {
var arrayList = [];
angular.forEach(value, function (val) {
angular.forEach(val[propertyName], function (v) {
arrayList.push(v)
});
});
return arrayList;
}
});
<强> HTML 强>
<ul>
<li ng-repeat="o in ordersList.orders | createarray: 'parcels'">{{o.upid}}</li>
</ul>
答案 2 :(得分:4)
好像你只需要一个双嵌套for循环 -
<ul>
<div ng-repeat="o in orders">
<li ng-repeat="p in o.parcels">{{p.upid}}</li>
</div>
</ul>
这里的HTML可能有点难看,但我不确定你到底想要什么。或者,您可以通过映射创建parcels
的新数组。
答案 3 :(得分:1)
大量搜索动态迭代的简单易用的解决方案。我想出了这个
JAVASCRIPT(angular):一个人是嵌套对象的一个例子。 is_object函数将在HTML视图中使用。
$scope.person = {
"name": "john",
"properties": {
"age": 25,
"sex": "m"
},
"salary": 1000
}
// helper method to check if a field is a nested object
$scope.is_object = function (something) {
return typeof (something) == 'object' ? true : false;
};
HTML:为简单表定义模板。第一个TD是显示的键。另一个TD(2或3,但从不两者)将显示该值,如果它不是一个对象(数字/字符串),如果它是一个对象,则再次循环。
<table border="1">
<tr ng-repeat="(k,v) in person">
<td> {{ k }} </td>
<td ng-if="is_object(v) == false"> {{ v }} </td>
<td ng-if="is_object(v)">
<table border="1">
<tr ng-repeat="(k2,v2) in v">
<td> {{ k2 }} </td>
<td> {{ v2 }} </td>
</tr>
</table>
</td>
</tr>
</table>
答案 4 :(得分:0)
<li ng-repeat="p in orders.parcels">{{p.upid}}</li>
无法按预期方式工作的原因是因为parcels数组是订单数组中每个订单内的对象,即它不是订单数组本身的对象。
如果您的orders数组是在控制器的$ scope上定义的,那么您可以在$scope
变量上创建数组:
$scope.allParcels = $scope.orders
.map(function (elem) {
return elem.parcels;
}) // get an array where each element is an array of parcels.
.reduce(function (previousValue, currentValue) {
return previousValue.concat(currentValue);
}); // concat each array of parcels into a single array of parcels
然后在模板上,您可以使用<li ng-repeat='p in allParcels'>{{p.upid}}</li>
但是,如果你不想将数组放在$scope
上,我相信你可以做类似的事情:
<li ng-repeat="p in orders
.map(function (elem) {
return elem.parcels;
})
.reduce(function (previousValue, currentValue) {
return previousValue.concat(currentValue);
})">{{p.upid}}</li>
虽然我不是100%确定Angular会评估ng-repeat
表达式中的.map / .reduce(同样在ng-repeat
中使用这种方式生成的数组也是不明智的必须经常通过map / reduce在每个$digest
周期生成一个新数组。