AngularJS ng-repeat 指令
定义和用法
ng-repeat 指令将一组HTML重复指定的次数。
HTML 集合中的每个项目将重复一次。
集合必须是数组或对象。
注意:重复的每个实例都会获得自己的作用域,该作用域由当前项目组成。
如果您有一个对象集合,ng-repeat 指令非常适合制作HTML表格,为每个对象显示一个表格行,并为每个对象属性显示一个表格数据。请参阅下面的示例。
实例
例子 1
为 records 数组中的每个项目写一个标题:
<body ng-app="myApp" ng-controller="myCtrl">
<h1 ng-repeat="x in records">{{x}}</h1>
<script>
var app = angular.module("myApp", []);
app.controller("myCtrl", function($scope) {
$scope.records = [
"Alfreds Futterkiste",
"Berglunds snabbköp",
"Centro comercial Moctezuma",
"Ernst Handel",
]
});
</script>
</body>
例子 2
为 records 数组中的每个项目写一个表格行:
<table ng-controller="myCtrl" border="1">
<tr ng-repeat="x in records">
<td>{{x.Name}}</td>
<td>{{x.Country}}</td>
</tr>
</table>
<script>
var app = angular.module("myApp", []);
app.controller("myCtrl", function($scope) {
$scope.records = [
{
"Name" : "Alfreds Futterkiste",
"Country" : "Germany"
},{
"Name" : "Berglunds snabbköp",
"Country" : "Sweden"
},{
"Name" : "Centro comercial Moctezuma",
"Country" : "Mexico"
},{
"Name" : "Ernst Handel",
"Country" : "Austria"
}
]
});
</script>
例子 3
为对象中的每个属性写一个表格行:
<table ng-controller="myCtrl" border="1">
<tr ng-repeat="(x, y) in myObj">
<td>{{x}}</td>
<td>{{y}}</td>
</tr>
</table>
<script>
var app = angular.module("myApp", []);
app.controller("myCtrl", function($scope) {
$scope.myObj = {
"Name" : "Alfreds Futterkiste",
"Country" : "Germany",
"City" : "Berlin"
}
});
</script>
语法
<element ng-repeat="expression"></element>
所有 HTML 元素都支持。
参数
| 参数 | 描述 |
|---|---|
| expression |
指定如何循环集合的表达式。 合法表达式示例:
|