ループ出力リストの多くのプロジェクトは Web サーバーで実行されます。フロントエンドはテンプレートを準備し、バックエンドは JSP コードを作成します。両者は緊密に連携して責任を分担する必要があります。一部のプロジェクトではバックエンドで RESTful メソッドが提供されており、フロントエンドは Ajax を使用して独自のループを呼び出しますが、これには多くの JQuery 文字列が含まれるため、あまりにも直感的ではありません。
AngularJS を使用する方がはるかに優れており、構文は JSP に似ています。
<!doctype html> <html ng-app> <head> <meta charset="utf-8"> <title>ng-repeat directive</title> </head> <body> <table ng-controller="CartController"> <caption>我的购物车</caption> <tr> <th>序号</th> <th>商品</th> <th>单价</th> <th>数量</th> <th>金额</th> <th>操作</th> </tr> <tr ng-repeat="item in items"> <td>{{$index + 1}}</td> <td>{{item.name}}</td> <td>{{item.price | currency}}</td> <td><input ng-model="item.quantity"></td> <td>{{item.quantity * item.price | currency}}</td> <td> <button ng-click="remove($index)">Remove</button> </td> </tr> </table> <script src="../lib/angularjs/1.2.26/angular.min.js"></script> <script> function CartController($scope) { $scope.items = [ {name: "雷柏(Rapoo) V500 机械游戏键盘 机械黄轴", quantity: 1, price: 199.00}, {name: "雷柏(Rapoo) V20 光学游戏鼠标 黑色烈焰版", quantity: 1, price: 139.00}, {name: "AngularJS权威教程", quantity: 2, price: 84.20} ]; $scope.remove = function (index) { $scope.items.splice(index, 1); } } </script> </body> </html>
ng-repeat ディレクティブは、コンテンツをループする必要がある要素上にあり、項目は配列内の単一オブジェクトのエイリアスです。 $index は、現在の参照オブジェクトの 0 から始まるシリアル番号を返すことができます。さらに、$first、$middle、$last は、現在の要素が最初、中間、最後であるかどうかを示すブール値を返すことができます。コレクション内の要素。