AngularJS tabeller

ng-repeat-instruktionen är mycket bra för att visa tabeller.

Visa data i tabell

Det är mycket enkelt att visa en tabell med AngularJS:

AngularJS exempel

<div ng-app="myApp" ng-controller="customersCtrl">
<table>
  <tr ng-repeat="x in names">
    <td>{{ x.Namn }}</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>

Prova själv

Visa med CSS-stil

För att göra det mer estetiskt tilltalande, kan du lägga till några CSS:er till sidan:

CSS-stil

<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>

Prova själv

Visa med orderBy-filter

För att sortera tabellen, lägg till orderBy Filter:

AngularJS Exempel

<table>
  <tr ng-repeat="x in names | orderBy : 'Land'">
    <td>{{ x.Namn }}</td>
    <td>{{ x.Country }}</td>
  </tr>
</table>

Prova själv

Visa med uppercase-filter

För att visa i stor bokstav, lägg till uppercase Filter:

AngularJS Exempel

<table>
  <tr ng-repeat="x in names">
    <td>{{ x.Namn }}</td>
    <td>{{ x.Land | uppercase }}</td>
  </tr>
</table>

Prova själv

Visa tabellindex ($index)

För att visa tabellindex, lägg till med $index av <td>:

AngularJS Exempel

<table>
  <tr ng-repeat="x in names">
    <td>{{ $index + 1 }}</td>
    <td>{{ x.Namn }}</td>
    <td>{{ x.Country }}</td>
  </tr>
</table>

Prova själv

Använd $even och $odd

AngularJS Exempel

<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>

Prova själv