2017年7月4日,我原本可以像其他同时一样早点回家,玩几把王者荣耀,但是我没有,因为我选择留下来,写一篇博客。

项目中经常性的会遇到什么点击“全选”按钮,勾中所有“单选按钮”,当所有单选按钮勾选后,全选按钮自动勾选,这里我并不是想说这是多么难的一个事情,我只是想炫耀下自己写的东西。
(勾选与否,是切换类名来实现的)换一个背景图片而已
1)页面内容(静态页)
<ul class='list-inline my-list-inline'>
<li class="action-check" ng-class="{'active':allHasChoice}" ng-click="clicktarget(true,tmp,dataList)">
<li>中文名称</li>
<li>英文名称</li>
<li>申请人类型</li>
<ul>
<div class="list-data">
<table>
<tbody>
<tr ng-repeat="tmp in dataList track by tmp.idTell"
ng-class="{true:'active',false:''}[targetChoice[tmp.idTell]==true]"
ng-click="ctmlicktarget(false,tmp,dataList)"
>
<td>
<span class="choice-icon"></span>
<span class="company-name over-flow-handel-style" title="{{tmp.chineseName}}"
ng-bind="tmp.cineseName"></span>
</td>
<td>
<span class="english-name over-flow-handel-style" title="{{tmp.englishName}}"
ng-bind="tmp.englishName"></span>
</td>
<td>
<span class="english-name over-flow-handel-style" title="{{tmp.abbreviation}}"
ng-bind="tmp.abbreviation"></span>
</td>
</tr>
</tbody>
</table>
2)js代码
首先当然有一个参数数组,用于经营经营渲染页面:
$scope.dataList=[
{'chineseName':'百度科技','englishName':'baidukeji','abbreviation':'小度','idTell':'bd'},
{'chineseName':'小牛科技','englishName':'xiaoniukeji','abbreviation':'小牛','idTell':'xn'},
{'chineseName':'京东科技','englishName':'jdkeji','abbreviation':'小京','idTell':'xj'},
{'chineseName':'顺风科技','englishName':'sfkeji','abbreviation':'小风','idTell':'xf'},
{'chineseName':'阿里科技','englishName':'alkeji','abbreviation':'小里','idTell':'xl'},
{'chineseName':'淘宝科技','englishName':'tbkeji','abbreviation':'小宝','idTell':'xb'},
{'chineseName':'天猫科技','englishName':'tmkeji','abbreviation':'小猫','idTell':'xm'}
];
定义一个数组用于存储,选中的选项
$scope.targetChoice=[];
定义一个很简单的方法:用于操作单选,全选的效果实现
$scope.clicktarget=function(isAllChoiceBtn,tmp,dataList){
//isAllChoiceBtn:用于表示用户点击的是否是全选按钮,tmp:是数据集合中的一个数据对象
var count=0;//记录被选中的子选项的个数
//说明用户点击的不是“全选”按钮
isAllChoiceBtn==false?(function(){
//当前选项取反
$scope.targetChoice[tmp.idTell]=!$scope.targetChoice[tmp.idTell];
//遍历数据集合,统计已经被购中的单选项
angular.foreach(dataList,function(v,k){
$scope.targetChoice[v.idTell]&& count++;
});
//如果count等于数据集合得长度,说明所有的单选被购中
count==dataList.length && $scope.allHasChoice=true:$scope.allHasChoice==false;
})()
//说明点击的"全选"按钮
:(function(){
$scope.allHasChoice=!$scope.allHasChoice;//状态取反
$scope.allHasChoice==false?
//说明取消全选
:angular.forEach(dataList,function(v,k){
$scope.targetChoice[v.idTell]=$scope.allHasChoice;
count=0;
})
//说明选中全选
:angular.forEach(dataList,function(v,k){
$scope.targetChioce[v.idTell]=$scope.allHasChoice;
count++;
});
})()
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# angular
# checkbox全选
# 全选
# angularjs
# 全选单选
# Angular.js实现多个checkbox只能选择一个的方法示例
# Angular.JS判断复选框checkbox是否选中并实时显示
# 单选
# 勾选
# 这是
# 小猫
# 遍历
# 很简单
# 想说
# 淘宝
# 来实现
# 换一个
# 小宝
# 大家多多
# 写一篇
# 有一个
# 小风
# 几把
# 京东
# 我只是
# 因为我
相关文章:
高端智能建站公司优选:品牌定制与SEO优化一站式服务
怎么将XML数据可视化 D3.js加载XML
建站之星CMS建站配置指南:模板选择与SEO优化技巧
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
较简单的网站制作软件有哪些,手机版网页制作用什么软件?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
如何在万网主机上快速搭建网站?
宁波免费建站如何选择可靠模板与平台?
Swift中循环语句中的转移语句 break 和 continue
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
如何选择域名并搭建高效网站?
,网站推广常用方法?
创业网站制作流程,创业网站可靠吗?
建站之星安装后界面空白如何解决?
动图在线制作网站有哪些,滑动动图图集怎么做?
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
如何设计高效校园网站?
广州建站公司哪家好?十大优质服务商推荐
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
高性价比服务器租赁——企业级配置与24小时运维服务
建站主机选购指南:核心配置优化与品牌推荐方案
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
制作电商网页,电商供应链怎么做?
如何用虚拟主机快速搭建网站?详细步骤解析
七夕网站制作视频,七夕大促活动怎么报名?
建站之星后台密码如何安全设置与找回?
C++如何编写函数模板?(泛型编程入门)
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
建站之星北京办公室:智能建站系统与小程序生成方案解析
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
如何通过远程VPS快速搭建个人网站?
网站代码制作软件有哪些,如何生成自己网站的代码?
建站主机助手选型指南:2025年热门推荐与高效部署技巧
建站之星官网登录失败?如何快速解决?
公司网站制作费用多少,为公司建立一个网站需要哪些费用?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
香港服务器如何优化才能显著提升网站加载速度?
如何获取PHP WAP自助建站系统源码?
网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?
建站之星如何防范黑客攻击与数据泄露?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
如何选择PHP开源工具快速搭建网站?
音响网站制作视频教程,隆霸音响官方网站?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
浅谈Javascript中的Label语句
寿县云建站:智能SEO优化与多行业模板快速上线指南
*请认真填写需求信息,我们会在24小时内与您取得联系。