Angular多选、全选、批量选择操作实例代码

网友投稿 309 2023-06-03


Angular多选、全选、批量选择操作实例代码

在前台开发过程中,列表批量选择是一个开发人员经常遇到的功能,列表批量选择的实现方式很多,但是原理基本相同,本文主要来讲Angularjs如何简单的实现列表批量选择功能。

首先来看html代码

&lhttp://t;thead>

单位

html里面简单建立一个表格,与批量选择相关的只有两处。

一处是第3行 ng-click="selectAll($event)" ,用来做全选的操作; ng-checked="isSelectedAll() 用来判断当前列表内容是否被全选。

一处是第12行 ng-click="updateSelection($event,item.id) ,用来对某一列数据进行选择操作; ng-checked="isSelected(item.id) http://用来判断当前列数据是否被选中。

然后需要在与该页面相对应的controller中实现与批量选择相关的方法

//创建变量用来保存选中结果

$scope.selected = [];

var updateSelected = function (action, id) {

if (action == 'add' && $scope.selected.indexOf(id) == -1) $scope.selected.push(id);

if (action == 'remove' && $scope.selected.indexOf(id) != -1) $scope.selected.splice($scope.selected.indexOf(id), 1);

};

//更新某一列数据的选择

$scope.updateSelection = function ($event, id) {

var checkbox = $event.target;

var action = (checkbox.checked ? 'add' : 'remove');

updateSelected(action, id);

};

//全选操作

$scope.selectAll = function ($event) {

var checkbox = $event.target;

var action = (checkbox.checked ? 'add' : 'remove');

for (var i = 0; i < $scope.content.length; i++) {

var contact = $scope.content[i];

updateSelected(action, contact.id);

}

};

$scope.isSelected = function (id) {

return $scope.selected.indexOf(id) >= 0;

};

$scope.isSelectedAll = function () {

return $scope.selected.length === $scope.content.length;

};

controller中主要是对html中用到的几个方法的实现,相对来讲实现代码还是比较简洁易懂的。

多选效果展示如下


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java中SpringSecurity密码错误5次锁定用户的实现方法
下一篇:微信小程序 wx.login解密出现乱码的问题解决办法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~