效果如图:

HTML代码:

<div class="form-group quanxian-wrap">
<label>项目</label>
<form class="form-horizontal" style="border-top-left-radius: 4px;border-top-right-radius: 4px;">
<div data-v-55b43bfa="" class="toolbar">
<div data-v-55b43bfa="" class="form-group">
//模糊查询
<div data-v-55b43bfa="" class="form-group-bd dropdown" style="width: 400px">
<input type="search" class="weui-search-bar__input weui-flex__item form-control" id="searchInput" placeholder="请输入项目名称" style="border: 1px solid #ccc;" v-model="search " required="">
</div>
//点击显示隐藏下拉框
<div class="form-group-ft">
<button data-v-55b43bfa="" type="button" id="dropdownMenu1" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true" class="btn btn-default dropdown-toggle" v-on:click="checkSelectedButton">已选项目:{{bizShowList.length}}<span data-v-55b43bfa="" class="caret"></span></button>
</div>
<div data-v-fc6e5168="" class="dropdown-menu" style="display: block;"v-if="showSelectedProjects">
<div data-v-fc6e5168="" class="form-group">
<div data-v-fc6e5168="" class="col-sm-12">
<div data-v-fc6e5168="" class="item-select" v-for="(item,index) in bizShowList">
<span data-v-fc6e5168="">{{item.name}}</span>
<a data-v-fc6e5168="" href="javascript:;" v-on:click="deleteSelectedItem" v-bind:title="index">
<i data-v-fc6e5168="" class="icon-del"></i>
</a>
</div>
</div>
</div>
</div>
</div>
</div>
</form>
//按片区分类,单选全选项目
<form class="form-horizontal">
<div class="form-group">
<div class="col-sm-12">
<div class="biz-list" v-for="(project,index) in getBizList" :style="{hidden: project.hidden}">
<div class="biz-list-hd cf"> //片区选择
<div class="checkbox" style="float: none;display: block;clear: both;" :style="{display: search ?'none':'block'}">
<label>
<input type="checkbox" v-model="project.checked" v-on:click="updateSelectedAreaList(index)">
<span >{{project.area}}</span>
</label>
</div>
</div>
<div class="biz-list-bd cf"> //项目选择
<div class="checkbox" v-for="(item,index) in project.data" :style="{display:item.name.indexOf(search) > -1?'block':'none'}">
<label>
<input type="checkbox" v-model="item.checked" v-on:click="updateSelectedProjectList"><span>{{item.name}}</span>
</label>
</div>
</div>
</div>
</div>
</div>
</form>
</div>

JS:

export default {
data() {
return {
showSelectedProjects: false,
search: '' };
},
computed: {
// 关联项目列表
getBizList() {
this.bizList = cloneObject(this.$store.state.user.bizList);
this.bizList.splice(0, 1);
let data = this.bizList;
console.log(333,data);
for(let i=0;i<data.length;i++) {
if (data[i].area ==='' || data[i].area === null) {
data[i].area = '暂无片区';
}
}
return this.regroup(this.bizList);
}
},
methods: {
// 转换数据显示格式
regroup(arr) {
var map = {},
dest = [];
// 对象数组 根据项目编号(id)字段 分组
for (var i = 0; i < arr.length; i++) {
var ai = arr[i];
if (!map[ai.area]) {
dest.push({
area: ai.area,
data: [ai]
});
map[ai.area] = ai;
} else {
for (var j = 0; j < dest.length; j++) {
var dj = dest[j];
if (dj.area === ai.area) {
dj.data.push(ai);
break;
}
}
}
}
return dest;
},
//删除已选项目
deleteSelectedItem(event) {
let index = event.target.parentNode.title;
let selectedItem = this.bizShowList[index];
if (!selectedItem) return;
this.bizShowList.forEach(item => {
if (item.appId == selectedItem.appId) {
item.checked = false;
}
});
this.updateSelectedProjectList();
},// 单个项目选中
updateSelectedProjectList() {
this.showSelectedProjects = false;
let list = [];
let bizData = this.getBizList;
for (let i = 0; i < bizData.length; i++) {
bizData[i].data.forEach(item => {
if (item.checked) {
list.push(item);
}
})
}
//判断如果该片区下所有项目被选中,则选中该片区,否则取消选中
for (let i = 0; i < bizData.length; i++) {
for (let j = 0; j < bizData[i].data.length; j++) { if (!bizData[i].data[j].checked) {
bizData[i].checked = false;
break
}
if (j === bizData[i].data.length - 1) {
bizData[i].checked = true;
}
} }
this.bizShowList = list;
},
// 片区选择
updateSelectedAreaList(index) {
this.showSelectedProjects = false; let list = [];
let bizData = this.getBizList;
   //选择片区,则将该片区下所有项目选中,取消则不选中
for (let j = 0; j < bizData[index].data.length; j++) {
bizData[index].data[j].checked = bizData[index].checked;
}
          //将最后选中的项目push到list数组中
for (let i = 0; i < bizData.length; i++) {
bizData[i].data.forEach(item => {
if (item.checked) {
list.push(item);
}
})
} this.bizShowList = list;
},
    }
}

js分类多选全选的更多相关文章

  1. JS中表格的全选和删除要注意的问题

    在项目开发中,由于刚刚开始做项目,我对js还不是很精通,所以在用js对表格的全选和删除中遇到了不少问题,后来通过查找资料解决了,之后总结了一下关于js表格的全选和删除出现的一些问题,希望能帮助到大家. ...

  2. 基于JQ的多选/全选/反选及获取选中的值

    <!-- author:青芒 --> <!DOCTYPE html> <html lang="en"> <head> <met ...

  3. Dynamic CRM 2013学习笔记(二十六)报表设计:Reporting Service报表 动态参数、参数多选全选、动态列、动态显示行字体颜色

    上次介绍过CRM里开始报表的一些注意事项:Dynamic CRM 2013学习笔记(十五)报表入门.开发工具及注意事项,本文继续介绍报表里的一些动态效果:动态显示参数,参数是从数据库里查询出来的:参数 ...

  4. Vue.js实现checkbox的全选和反选

    小颖之前写的代码存在一个bug,就是当你选择全选的时候去掉后面的一个选项,再点全选结果就是反的了.很感谢博客园的朋友帮我改了这个问题嘻嘻,下面一起来看看具体是怎么实现的吧. 1.html <te ...

  5. vue.js 批量删除跟全选,反选效果

    <!DOCTYPE html><html lang="en"> <head> <meta charset="UTF-8" ...

  6. js实现checkbox的全选和全不选功能

    html代码: <form name="form1" method="post" action="manage.php?act=sub" ...

  7. <一>初探js特效魅力之全选不选反选04

    初探js特效魅力04 我们在进入到公司里面工作的时候,做一个同一个项目,经常是大家分工合作,当我们写css时,一般不写在行间,因为这样会被误操作,也就是被乱删了都不知道,这样的后果是很难检查的 ,因为 ...

  8. asp.net中Repeater结合js实现checkbox的全选/全不选

    前台界面代码: <input name="CheckAll" type="checkbox" id="CheckAll" value= ...

  9. js和jq实现全选反选

    在前端中用到全选反选的案例并不少,在这里呢我就实现这个功能给大家参考参考. 这里呢就先贴上我的html和css代码 <div class="wrap"> <tab ...

随机推荐

  1. 关于java文件名字影响系统配置

    测试OAM和OIF单点登录过程中,wlsh.sh中一个命令运行不过.查看一个java文件中有_en标示.修改名称,去掉_en后可以通过.

  2. scrum3

    首先我一直做的是框架的设计,但不同的是这次我们整合完善了这个软件目前的所有需求也定义好了它的大题框架,总的来说设计部分已经结束,现在也就是本次冲刺,我们将重点进行整个软件的数据库编程环节,也就是用SQ ...

  3. 【LOJ6062】「2017 山东一轮集训 Day2」Pair(线段树套路题)

    点此看题面 大致题意: 给出一个长度为\(n\)的数列\(a\)和一个长度为\(m\)的数列\(b\),求\(a\)有多少个长度为\(m\)的子串与\(b\)匹配.数列匹配指存在一种方案使两个数列中的 ...

  4. H5与安卓、IOS的交互,判断微信、移动设备、安卓、ios

    一.通过用户代理可以判断网页当前所在的环境 var browser={ versions:function(){ var u = navigator.userAgent, app = navigato ...

  5. Android学习笔记_13_网络通信之多个上传文件

    一.获取HTTP协议: 建立一个Web项目,建立一个如下所示的jsp界面,用IE捕获表单提交信息. <%@ page language="java" contentType= ...

  6. 【字符串】跳来跳去的KMP匹配

    原理: 不给予证明啦(懒得一批 但是代码中有给还算详细的注释 参考:https://www.cnblogs.com/yjiyjige/p/3263858.html 模板题: 洛谷P3375: http ...

  7. [Oracle]Audit(一)--认识Audit

    1.Audit的概念 Audit是监视和记录用户对数据库进行的操作,以供DBA进行问题分析.利用Audit功能,可以完成以下任务: 监视和收集特定数据库活动的数据.例如管理员能够审计哪些表被更新,在某 ...

  8. c/c++面试----c工程开发之头文件

    多数c语言的初学者对c工程开发过程各个阶段的作用理解不到位,而这方面的的知识又是实际开发过程中经常用到的技能点,所以就成为面试考察中一个重要的考察方面.例如:头文件的作用.头文件的内容:链接的作用和意 ...

  9. [HAOI2007]理想的正方形(随机化,骗分?)

    题目描述 有一个a*b的整数组成的矩阵,现请你从中找出一个n*n的正方形区域,使得该区域所有数中的最大值和最小值的差最小. 输入输出格式 输入格式: 第一行为3个整数,分别表示a,b,n的值 第二行至 ...

  10. IOException parsing XML document from ServletContext resource [/WEB-INF/applicationContext.xml]; nested exception is java.io.FileNotFoundException: Could not open ServletContext resource [/WEB-INF/app

    web.xml初始化spring容器出错 org.springframework.beans.factory.BeanDefinitionStoreException: IOException par ...