批量删除+单个删除+全选反选

来源:互联网 发布:plsql编程入门 编辑:程序博客网 时间:2024/05/16 10:38
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <script src="js/angular.min.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body ng-app="myApp" ng-controller="myCtrl">
        
        商品名<input type="text" ng-model="gname"/>
        单价<input type="text" ng-model="gprice"/>
        数量<input type="text" ng-model="gnum"/>
        <input type="button" value="添加" ng-click="add()"/>
        <input type="button"  value="批量删除" ng-click="piliang()"/>
        <table border="1px" cellspacing="0px" cellpadding="0px">
            <thead>
                <tr>
                    <td><input type="checkbox" ng-model="selectAll" ng-click="all(selectAll)"/></td>
                    <td>商品名</td>
                    <td>单价</td>
                    <td>数量</td>
                    <td>总额</td>
                    <td>操作</td>
                </tr>
            </thead>
            <tr ng-repeat="g in goods">
                <td><input type="checkbox" ng-click="xuanzhong($index)" ng-model="g.flag"/></td>
                <td>{{g.gname}}</td>
                <td>{{g.gprice}}</td>
                <td>{{g.gnum}}</td>
                <td>{{g.gprice*g.gnum}}</td>
                <td><button ng-click="dle($index)">删除</button></td>
            </tr>
        </table>
        
        <script type="text/javascript">
            var mo = angular.module("myApp",[]);
            mo.controller("myCtrl",function($scope){
                
                //定义数组
                $scope.goods = [{"flag":false,"gname":"足球","gprice":3,"gnum":6},
                                {"flag":false,"gname":"篮球","gprice":8,"gnum":3},
                                {"flag":false,"gname":"棒球","gprice":10,"gnum":4}];
                
                //添加
                $scope.add = function(){
                    
                    //创建对象
                    var good = {"flag":false,"gname":$scope.gname,"gprice":$scope.gprice,"gnum":$scope.gnum};
                    //将对象放入数组
                    $scope.goods.push(good);
//                    $scope.goods.unshift();//向第一个位置添加
                    
                }
                //根据复习框的索引,改变flag值
//                $scope.xuanzhong = function($index){
//                    $scope.goods[$index].flag = !$scope.goods[$index].flag;
//                }
                //批量删除
                $scope.piliang = function(){
                    //反着遍历
                    for(var i = $scope.goods.length-1;i>=0;i--){
                        var g = $scope.goods[i];
                        if(g.flag){
                            $scope.goods.splice(i,1);
                        }
                    }
                }
                //单个删除
                $scope.dle=function($index){
                    $scope.goods.splice($index,1);
                }
                
                //单选全选
                   
                $scope.all= function (m) {  
                    for(var i=0;i<$scope.goods.length;i++){  
                      if(m===true){  
                          $scope.goods[i].flag=true;  
                      }else {  
                          $scope.goods[i].flag=false;  
                      }  
                    }  
                };  
                
            });
        </script>
        
    </body>
</html>

阅读全文
0 0
原创粉丝点击