AngularJS实现数据列表的增加、删除和上移下移等功能实例
程序员文章站
2022-06-30 18:59:01
效果图
实例代码
效果图
实例代码
<!doctype html> <html lang="en" ng-app="myapp" ng-controller="myctrl"> <head> <meta charset="utf-8"> <title>title</title> <style> *{margin:0;padding:0; list-style: none;font-size:12px;} .clearfix{overflow: hidden;display:block;clear:both} .clearfix:after{zoom:1} .relation{margin-top:7px;font:14px/38px "微软雅黑"; height: 38px; background: #f8f8f8; padding-left: 26px; color: #666;} .relation li{ margin-top: 5px;float:left;padding-left:50px;cursor:pointer;text-decoration: double} .relation li:hover{color:#f00}; .tablemain li{float:left;padding:5px 10px;width:50px} .ullist1 li.num39{width: 39px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num73{width: 73px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num85{width: 85px; height: 36px; line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num114{width:140px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num122{width:170px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num167{width:180px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num185{width:185px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num70{width:70px;height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num103{width:183px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ullist1 li.num97{width:160px; height: 36px;line-height: 36px; text-align: center; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num39{width: 39px;height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num73{width: 73px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num85{width: 85px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num114{width:140px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num122{width:170px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num167{width:180px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num185{width:185px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num70{width:70px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num103{width:183px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num97{width:160px; height: 42px; line-height: 42px; float: left; border-right: 1px solid #ddd;} .ulconter1 li.num39 input{ width:19px; height: 19px; margin:11px; border: 1px solid #ddd; } .ulconter1 li.num73 input{ width:68px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num85 input{ width:80px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num114 input{ width:135px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num122 input{ width:165px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num167 input{ width:175px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num185 input{ width:180px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num70 input{ width:65px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num103 input{ width:178px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} .ulconter1 li.num97 input{ width:150px; border: 1px solid #ddd; margin: 2px;line-height: 32px; height: 32px;} </style> <script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <ul class="relation clearfix"> <li class="news" ng-click="others.addcontact()">新增</li> <li class="dele" ng-click="others.delecontact()">删除</li> <li class="upico" ng-click="others.moveup()">上移</li> <li class="downico" ng-click="others.movedown()">下移</li> </ul> <div class="class="tablemain""> <ol class="clearfix ullist1"> <li class="num39"></li> <li class="num73">联系人</li> <li class="num85">商务电话</li> <li class="num114">移动电话</li> <li class="num122">qq</li> <li class="num122">skype</li> <li class="num167">电子邮件</li> </ol> <ul class="ulconter1 clearfix" ng-repeat="item in items" > <li class="num39"> <input type="radio" ng-click="others.selected(item)" name="select"> </li> <li class="num73"> <input type="text" ng-model="item.othercontact"> </li> <li class="num85"> <input type="text" ng-model="item.otherbusinesstel" > </li> <li class="num114"> <input type="text" ng-model="item.othermobphone" > </li> <li class="num122"> <input type="text" ng-model="item.otherqq" > </li> <li class="num122"> <input type="text" ng-model="item.otherskype" > </li> <li class="num167"> <input type="text" ng-model="item.otheremail"> </li> </ul> </div> <script> angular.module('myapp',[]).controller('myctrl',function($scope){ $scope.items=[]; $scope.others={ selecteditem:{}, selected:function(item){ this.selecteditem=item; }, //增加 addcontact:function(){ $scope.items.push({ othercontact:'', otherbusinesstel:'', othermobphone:'', otherqq:'', otherskype:'', otheremail:'', otherdeliveryaddress:'', othersex:'', otherdepartment:'' }); }, //刪除; delecontact:function(){ var index=$scope.items.indexof(this.selecteditem); $scope.items.splice(index,1); }, //上移; moveup:function(){ var index=$scope.items.indexof(this.selecteditem); var tmp=angular.copy($scope.items[index-1]); if(index==0){ alert('已經是第一個了,不能再向上移動了!'); return ; } $scope.items[index-1]=$scope.items[index]; $scope.items[index]=tmp; }, //下移; movedown:function(){ var index=$scope.items.indexof(this.selecteditem); if(index==$scope.items.length-1){ alert('已經是最後一個了,不能再向下移動了!'); return ; } var tmp=angular.copy($scope.items[index+1]); $scope.items[index+1]=$scope.items[index]; $scope.items[index]=tmp; } } }) </script> </body> </html>
总结
以上就是这篇文章的全部内容,大家可以自己实践后看下效果,这样更利于大家的理解和学习,希望本文对大家学习或使用angularjs能有所帮助。如果有疑问可以留言交流,谢谢大家对的支持。