AngularJS 表格
ng-repeat 指令可以完美的显示表格。
在表格中显示数据
使用 angular 显示表格是非常简单的:
<div ng-app="myApp" ng-controller="customersCtrl">
<table>
<tr ng-repeat="x in names">
<td>{{ x.Name}}</td>
<td>{{ x.Country}}</td>
</tr>
</table>
</div>
<script>
var app = angular.module('myApp',[]);
app.controller('customersCtrl',function($scope, $http){
$http.get("test.php")
.success(function(response){$scope.names = response.records;});
});
</script>
moyu:
data:image/s3,"s3://crabby-images/13212/132129b16ebde299dfab8a604b920286af8eabd1" alt=""
使用 CSS 样式
为了让页面更加美观,我们可以在页面中使用CSS:
<style>
table, th , td {
border:1px solid grey;
border-collapse: collapse;
padding:5px;
}
table tr:nth-child(odd){
background-color:#f1f1f1;
}
table tr:nth-child(even){
background-color:#ffffff;
}
</style>
结果:
data:image/s3,"s3://crabby-images/c1cdc/c1cdc00be0673fbf1039f3803114af62459d5157" alt=""
使用 orderBy 过滤器
排序显示,可以使用 orderBy 过滤器:
<table>
<tr ng-repeat="x in names | orderBy : 'Country'">
<td>{{ x.Name}}</td>
<td>{{ x.Country}}</td>
</tr>
</table>
结果:
data:image/s3,"s3://crabby-images/0eaf8/0eaf841475687f9c1080041eeae8c548aa4b4fb6" alt=""
使用 uppercase 过滤器
使用 uppercase 过滤器转换为大写:
<table>
<tr ng-repeat="x in names">
<td>{{ x.Name}}</td>
<td>{{ x.Country| uppercase }}</td>
</tr>
</table>
结果:
data:image/s3,"s3://crabby-images/eb20c/eb20c0ebca5c5c3ce49653d8c0780029d98e346d" alt=""
显示序号 ($index)
表格显示序号可以在 <td> 中添加 $index:
<table>
<tr ng-repeat="x in names">
<td>{{ $index +1}}</td>
<td>{{ x.Name}}</td>
<td>{{ x.Country}}</td>
</tr>
</table>
魔芋结果:
data:image/s3,"s3://crabby-images/285a6/285a6e9c1a3c979aee2ca2be3ed945e010144251" alt=""
使用 $even 和 $odd
<table>
<tr ng-repeat="x in names">
<td ng-if="$odd" style="background-color:#f1f1f1">{{ x.Name}}</td>
<td ng-if="$even">{{ x.Name}}</td>
<td ng-if="$odd" style="background-color:#f1f1f1">{{ x.Country}}</td>
<td ng-if="$even">{{ x.Country}}</td>
</tr>
</table>
结果:
data:image/s3,"s3://crabby-images/7e80a/7e80ad42c13670cf00bee118f8e63332e1fb04ce" alt=""