vue结合element UI做checkbox全选的tree结构
由于element UI中的tree可能不能满足项目中的样式需求,所以自己动手结合element中的checkbox全选功能实现了一个符合项目需求的tree。效果如下:
html部分:
<template>
<div class="tree-container">
<div v-for="(item,index) in menus" :key="index">
<p class="toggleIcon" @click="toggleShow(item)">{{item.isShowAll?'-':'+'}}</p>
<el-checkbox :indeterminate="item.isIndeterminate" v-model="item.checkAll" @change="((val)=>{handleCheckAllChange(item,val)})">
{{item.name}}
</el-checkbox>
<span class="checkBox-num">{{item.num}}</span>
<el-checkbox-group v-model="item.checkedCities" @change="((val)=>{handleCheckedCitiesChange(item,val)})" class="checkGroup" v-if="item.isShowAll">
<el-checkbox v-for="(it,i) in item.userList" :key="i" :label="it.num" @change="((val)=>{handleCheckedOne(it,val)})">
<label class="icon-zhu" v-if="it.telType == '移动电话' && numList.indexOf(it.num)>=0 ">
<span :class="numList[0] === it.num?'colorful-icon':''">主</span>
</label>
<label class="tree-text">
{{it.telType}}
<span v-if="it.cardType">({{it.cardType}})</span>
</label>
<label class="tree-text">{{it.num}}</label>
<label class="tree-text">{{it.label}}</label>
</el-checkbox>
</el-checkbox-group>
</div>
</div>
</template>
js部分:
export default {
name: "Tree",
props: ["menus", "formData", "numList"],
methods: {
// 是否展开checkbox
toggleShow(item) {
item.isShowAll = !item.isShowAll;
}, handleCheckAllChange(item, val) {
if (val) {
item.userList.map(it = > {
let numIndex = this.numList.indexOf(it.num);
item.checkedCities.push(it.num);
this.formData.userNum = Array.from(new Set(this.formData.userNum.concat(item.checkedCities)));
if (it.telType == "移动电话") {
this.numList.push(it.num);
}
});
} else {
item.userList.map(it = > {
let Index = this.formData.userNum.indexOf(it.num);
let numIndex = this.numList.indexOf(it.num);
if (Index > -1) {
this.formData.userNum.splice(Index, 1);
}
if (numIndex > -1) {
this.numList.splice(numIndex, 1);
}
});
item.checkedCities = [];
}
item.isIndeterminate = false;
}, handleCheckedCitiesChange(item, val) {
let checkedCount = val.length;
item.checkAll = checkedCount === item.userList.length;
item.isIndeterminate = checkedCount > 0 && checkedCount < item.userList.length;
}, handleCheckedOne(item, val) {
let Index = this.formData.userNum.indexOf(item.num);
let numIndex = this.numList.indexOf(item.num);
//如果找到了,有此值
if (Index > -1) {
this.formData.userNum.splice(Index, 1);
} else {
this.formData.userNum.push(item.num);
}
if (item.telType == "移动电话") {
if (numIndex > -1) {
this.numList.splice(numIndex, 1);
} else {
this.numList.push(item.num);
}
}
}
}
};
css样式
<style lang="scss" scoped> @import "../../../assets/css/base.scss";
.tree-container {
width: 100%;
position: relative;
padding: 10px;
&>div {
margin-left: 20px;
} .toggleIcon {
width: 14px;
height: 14px;
border: 1px solid #dcdcdc;
@include wordStyle(#dcdcdc, 14px, 600); text-align: center;
line-height: 11px;
cursor: pointer;
position: absolute;
left: 10px;
margin-top: 10px;
} .checkGroup {
display: flex;
flex-direction: column;
padding-left: 20px;
}
/deep/ .el-checkbox {
&+.el-checkbox {
margin-left: 0;
}
}
/deep/ .el-checkbox__inner {
&: hover {
border-color: #ed795a;
}
&:focus {
border: 1px solid #dcdfe6;
outline: none;
}
}
/deep/ .el-checkbox__input {
&.is-checked,&.is-indeterminate {
.el-checkbox__inner {
background-color: #ed795a;
border-color: #ed795a;
}
}
&.is-checked {
&+.el-checkbox__label {
color: #ed795a;
}
}
}
/deep/ .el-checkbox__label {
font-size: 12px;
padding-left: 0;
}
/deep/ .el-checkbox {
position: relative;
} .icon-zhu {
position: absolute;
left: -24px;
span { display: inline-block;
width: 18px;
height: 18px;
line-height: 18px;
text-align: center;
border-radius: 100%;
color: #fff;
font-weight: bold;
background-color: #ccc;
} .colorful-icon {
background-color: #ed795a;
}
.checkBox-num {
position: absolute;
right: 10px;
font-size: 12px;
}
}
</style>
数据结构如下
menus: [{
id: "1",
name: "不限量173套餐",
num: "23789446464646",
checkAll: false,
checkedCities: [],
//v-model绑定
isIndeterminate: false,
//设置 indeterminate 状态,只负责样式控制
isShowAll: true,
//控制展开和收缩的状态
userList: [{
id: "1.1",
username: "html",
role: "主管",
telType: "移动电话",
cardType: "主号",
label: "现行",
num: "17316065935"
}, {
id: "1.2",
username: "vue",
role: "普通",
telType: "有线宽带",
cardType: "",
label: "现行",
num: "hz87654321"
}, {
id: "1.3",
username: "vue",
role: "普通",
telType: "移动电话",
cardType: "副号",
label: "现行",
num: "17316065937"
}]
}, {
id: "1",
name: "不限量199套餐",
num: "23789446464646",
checkAll: false,
checkedCities: [],
//v-model绑定
isIndeterminate: false,
//设置 indeterminate 状态,只负责样式控制
isShowAll: true,
userList: [{
id: "1.1",
username: "html",
role: "主管",
telType: "有线宽带",
cardType: "",
label: "现行",
num: "hz1234567"
}, {
id: "1.2",
username: "vue",
role: "普通",
telType: "移动电话",
cardType: "副号",
label: "现行",
num: "19916065934"
}, {
id: "1.3",
username: "vue",
role: "普通",
telType: "移动电话",
cardType: "副号",
label: "现行",
num: "19916065936"
}]
}]
vue结合element UI做checkbox全选的tree结构的更多相关文章
- angularjs实现 checkbox全选、反选的思考
之前做了一周的打酱油测试,其实感觉其实测试也是上辈子折翼的天使. 好长时间没写代码,感觉好多都不会了. 感谢这周没有单休,我能看熬夜看奥运了.我能有时间出去看个电影,我能有时间出去逛个商城,我能有时间 ...
- jQuery设置checkbox全选(区别jQuery版本)
jQuery设置checkbox全选在网上有各种文章介绍,但是为什么在我们用他们的代码的时候就没有效果呢? 如果你的代码一点错误都没有,先不要急着怀疑人家代码的正确性,也许只是人家跟你用的jQuery ...
- Jquery学习之路(一) 实现checkbox全选方法
昨天早上有写到怎么利用Jquery实现全选 根据大家的意见对程序中一些写法不好的地方进行了修改,也是本人水平有限,存在各种考虑不到的地方. 文章最后我提出了一个问题,要写一个通用的方法来调用,于是就有 ...
- 关于input[type='checkbox']全选的问题
今天在做一个全选功能的时候,发现了一个问题,就是如果我在选择全选之前,我就已经选择了一个input,然后我再去选择全选并且以后再取消全选的时候,这个我之前选择的input始终处于选择状态,但是他的ch ...
- vue 入门 ------简单购物车功能实现(全选,数量加减,价格加减)
简易购物车功能(无任何布局 主要是功能) 数量的加减 商品的总价钱 全选与全不选 删除(全选.价格 受影响) <script src="https://cdn.jsdelivr.net ...
- vue实现功能 单选 取消单选 全选 取消全选
vue实现功能 单选 取消单选 全选 取消全选 代码部分 <template> <div class=""> <h1>全选框</h1> ...
- TreeView checkbox 全选
在使用TreeView 控件 ,进行权限管理的时候,需要使用 checkbox全选. 勾选父节点,子节点全部选中.取消父节点,子节点不选中. 勾选子节点,父节点也选中. 以下是在使用的例子: < ...
- JS checkbox 全选 全不选
/* JS checkbox 全选 全不选 Html中checkbox: <input type="checkbox" name="cbx" value= ...
- checkbox全选,反选,取消选择 jquery
checkbox全选,反选,取消选择 jquery. //checkbox全部选择 $(":checkbox[name='osfipin']").each(function(){ ...
- js初学—实现checkbox全选功能
布局如下: <p ><input type="checkbox" id="che1"/>全选</p><div id=& ...
随机推荐
- 【YashanDB知识库】yasdb jdbc驱动集成BeetISQL中间件,业务(java)报autoAssignKey failure异常
问题现象 BeetISQL中间件版本:2.13.8.RELEASE 客户在调用BeetISQL提供的api向yashandb的表中执行batch insert并将返回sequence设置到传入的jav ...
- git 批量删除本地分支及远程分支
git 批量删除本地分支及远程分支 一.批量删除本地分支 git branch |grep 'name' |xargs git branch -D 备注: name 为需要匹配的分支名称 二.批量删除 ...
- echarts的x轴显示不全的解决办法
echarts的x轴显示不全的解决办法 一.背景 当x轴类目较多时,label显示时会自动间隔显示,也就是会隐藏掉中间的label,如下图: 二.解决办法 通过设置 xAxis.axisLabel.i ...
- 扫描全能王启动鸿蒙原生应用开发,系HarmonyOS NEXT智能扫描领域首批
近期,"鸿蒙合作签约暨扫描全能王鸿蒙原生应用开发启动仪式"(简称"签约仪式")正式举行.合合信息与华为达成鸿蒙合作,旗下扫描全能王将基于HarmonyOS NE ...
- QT6 QML编程
QT6 QML编程 使用AI技术辅助生成 QT界面美化视频课程 QT性能优化视频课程 QT原理与源码分析视频课程 QT QML C++扩展开发视频课程 免费QT视频课程 您可以看免费1000+个QT技 ...
- Linux操作系统和文件系统、常见命令(下)
C语言的绝大部分内容应该记录在以.c作为拓展名的文件里,这种文件叫做C语言的源文件 C语言程序里还包括以.h作为拓展名的文件,这种文件叫头文件(只有极少数的内容可以记录在头文件里) C语言程序里可以使 ...
- 修改Kubernetes主节点(控制节点)名称
1.修改物理机主机名 hostnamectl set-hostname <hostname> 2.修改 /etc/kubernetes/manifests 目录下的文件,将文件内容包含旧主 ...
- C#/.NET/.NET Core技术前沿周刊 | 第 8 期(2024年10.01-10.06)
前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录.追踪C#/.NET/.NET Core领域.生态的每周最新.最实用.最有价值的技术文章.社区动态.优质项目和学习资源等. ...
- USB2.0 的LPM和USB3.0的LPM区别
USB 2.0 和 USB 3.0 都支持低功耗管理机制(LPM,Link Power Management),但两者的实现方式和目标不同.以下是 USB 2.0 的 LPM 和 USB 3.0 的 ...
- USB协议详解第6讲(USB描述符-端点描述符)
1.USB描述符 USB描述符有设备描述符.标准配置描述符.接口描述符.端点描述符.字符串描述符,HID设备有HID描述符.报告描述符和物理描述符.今天主要是学习USB端点描述符的组成. 2.端点描述 ...