ตาราง AngularJS
คำสั่ง ng-repeat นั้นสมบูรณ์แบบสำหรับการแสดงตาราง
การแสดงข้อมูลในตาราง
การแสดงตารางที่มีมุมนั้นง่ายมาก:
ตัวอย่าง AngularJS
<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("customers.php")
.then(function (response) {$scope.names = response.data.records;});
});
</script>
แสดงด้วย CSS Style
เพื่อให้ดูดี ให้เพิ่ม 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>
แสดงตามลำดับโดยตัวกรอง
ในการเรียงลำดับตาราง ให้เพิ่มตัวกรอง orderBy :
ตัวอย่าง AngularJS
<table>
<tr ng-repeat="x in names | orderBy : 'Country'">
<td>{{ x.Name }}</td>
<td>{{ x.Country }}</td>
</tr>
</table>
แสดงผลด้วยตัวกรองตัวพิมพ์ใหญ่
หากต้องการแสดงตัวพิมพ์ใหญ่ ให้เพิ่มตัวกรองตัวพิมพ์ใหญ่:
ตัวอย่าง AngularJS
<table>
<tr ng-repeat="x in names">
<td>{{ x.Name }}</td>
<td>{{ x.Country
| uppercase }}</td>
</tr>
</table>
แสดงดัชนีตาราง ($index)
หากต้องการแสดงดัชนีตาราง ให้เพิ่ม <td> ด้วย$index :
ตัวอย่าง AngularJS
<table>
<tr ng-repeat="x in names">
<td>{{ $index + 1 }}</td>
<td>{{ x.Name }}</td>
<td>{{ x.Country }}</td>
</tr>
</table>
ใช้ $even และ $odd
ตัวอย่าง AngularJS
<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>