发表于: 2020-03-20 23:52:53

1 1615


今天完成的事情:今天学习了AngularJS 表格的一些内容
明天计划的事情:继续学习AngularJS的后续的内容
遇到的问题:实际操作还是太少实现的内容还需要进行深刻理解
收获:ng-repeat 指令可以完美的显示表格。例如

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>
</head>
<body>

<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("/try/angularjs/data/Customers_JSON.php")
    .then(function (result) {
        $scope.names = result.data.records;
    });
});
</script>

</body>
</html>

运行结果

加上样式

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>
  <style>
    table,
    th,
    td {
      border1px solid grey;
      border-collapsecollapse;
      padding5px;
    }

    table tr:nth-child(odd) {
      background-color#f1f1f1;
    }

    table tr:nth-child(even) {
      background-color#ffffff;
    }
  </style>
</head>

<body>

  <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("/try/angularjs/data/Customers_JSON.php")
        .then(function (result) {
          $scope.names = result.data.records;
        });
    });
  </script>

</body>

</html>

运行结果

排序显示,可以使用 orderBy 过滤器: 

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>
  <style>
    table,
    th,
    td {
      border1px solid grey;
      border-collapsecollapse;
      padding5px;
    }

    table tr:nth-child(odd) {
      background-color#f1f1f1;
    }

    table tr:nth-child(even) {
      background-color#ffffff;
    }
  </style>
</head>

<body>

  <div ng-app="myApp" ng-controller="customersCtrl">

    <table>
      <tr ng-repeat="x in names | orderBy : 'Country'">
        <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("/try/angularjs/data/Customers_JSON.php")
        .then(function (result) {
          $scope.names = result.data.records;
        });
    });
  </script>

</body>

</html>

运行结果

按字母排序

使用 uppercase 过滤器转换为大写: 

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>
  <style>
    table,
    th,
    td {
      border1px solid grey;
      border-collapsecollapse;
      padding5px;
    }

    table tr:nth-child(odd) {
      background-color#f1f1f1;
    }

    table tr:nth-child(even) {
      background-color#ffffff;
    }
  </style>
</head>

<body>

  <div ng-app="myApp" ng-controller="customersCtrl">

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

  </div>

  <script>
    var app = angular.module('myApp', []);
    app.controller('customersCtrl'function ($scope$http) {
      $http.get("/try/angularjs/data/Customers_JSON.php")
        .then(function (result) {
          $scope.names = result.data.records;
        });
    });
  </script>

</body>

</html>

运行结果

都改成了大写

表格显示序号可以在 <td> 中添加 $index: 

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>
  <style>
    table,
    th,
    td {
      border1px solid grey;
      border-collapsecollapse;
      padding5px;
    }

    table tr:nth-child(odd) {
      background-color#f1f1f1;
    }

    table tr:nth-child(even) {
      background-color#ffffff;
    }
  </style>
</head>

<body>

  <div ng-app="myApp" ng-controller="customersCtrl">

    <table>
      <tr ng-repeat="x in names">
        <td>{{ $index + 1 }}</td>
        <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("/try/angularjs/data/Customers_JSON.php")
        .then(function (result) {
          $scope.names = result.data.records;
        });
    });
  </script>

</body>

</html>

运行结果

加上序号了

使用 $even 和 $odd

<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <script src="https://cdn.staticfile.org/angular.js/1.6.3/angular.min.js"></script>
  <style>
    table,
    td {
      border1px solid grey;
      border-collapsecollapse;
      padding5px;
    }
  </style>
</head>

<body>

  <div ng-app="myApp" ng-controller="customersCtrl">

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

  </div>

  <script>
    var app = angular.module('myApp', []);
    app.controller('customersCtrl'function ($scope$http) {
      $http.get("/try/angularjs/data/Customers_JSON.php")
        .then(function (result) {
          $scope.names = result.data.records;
        });
    });
  </script>

</body>

</html>

运行结果

前面按字母排序

剩下的明天再继续进行


返回列表 返回列表
评论

    分享到