element树形控件(tree)实现父与子关联,子与父不关联;手动设置半选状态

本文主要是介绍element树形控件(tree)实现父与子关联,子与父不关联;手动设置半选状态,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

element树形控件(tree)实现父与子关联,子与父不关联;手动设置半选状态

首先,树组件的代码

<el-treeref="tree" :data="list" node-key="name" show-checkbox :props="defaultProps" highlight-current check-strictly @check="handCheck" @check-change="checkChange" :default-checked-keys="checkedKeys" />

重点用到的方法
在这里插入图片描述

在这里插入图片描述
check-strictly这个字段要设置为true,父子节点才能互不关联。这样我们才能自己来做节点关联与否的操作。

然后是,功能实现的代码

共三层树节点:1、菜单父节点权限;2、菜单权限;3、按钮权限

默认显示的勾选状态

getPermissions(_this.ur, _this.roleName).then((result) => {let _this = this_this.list = result.groups;const tree = [];_this.list.forEach((listItem) => {//因为子节点最内层的子节点比较好操作,省去了一段代码//..............................//子节点添加勾选状态tree.push(listItem);})_this.$nextTick(() => {_this.$refs.tree.setCheckedNodes(_this.pertemp);});// console.log(tree);// 设置父级节点的勾选状态let checkChild = []tree.forEach(item => {// 如果有子级并且只要有一个子级的isGranted为trueif (item.children && item.children.some(ele => ele.isGranted)) {// 就默认设置最外层父节点为勾选状态。筛选isGranted为true的二级节点也设置为勾选状态checkChild.push(item.name, item.children.filter(child => child.isGranted).map(child => { return child.name }))}});_this.$nextTick(() => {_this.checkedKeys = checkChild.flat()setTimeout(() => {// 父级节点tree && tree.length > 0 && setIndeterminate(tree, 'tree')function setIndeterminate (node, treeName) {node.forEach(item => {let treeNode = _this.$refs[treeName].getNode(item);// 如果子节点未全部选中,则设置父节点为半选状态if (treeNode.childNodes.map(ele => ele.checked ).some(ele => !ele)) {treeNode.indeterminate = true}// 如果子节点全部未选中取消父节点的半选中状态if (treeNode.childNodes.every(ele => !ele.checked)) {// treeNode.checked = falsetreeNode.indeterminate = false}// 如果是二级节点,子节点全不选但是当前节点是勾选状态的时候,默认设置变为半选状态if (treeNode.level == 2 && treeNode.checked && treeNode.childNodes.every(ele => !ele.checked)) {treeNode.indeterminate = true}// console.log(treeNode);// 子节点递归item.children && item.children.length > 0 && setIndeterminate(item.children, 'tree')});}}, 500);})}).catch((err) => {console.log(err);});

点击节点时勾选状态的操作

// 覆盖原有勾选功能,父与子关联,子与父不关联handCheck (data, node) {this.hanleCheck(data, node, 'tree')},hanleCheck (data, node, treeName) {// console.log(data, node);const _this = this// 获取当前节点是否被选中const isChecked = _this.$refs[treeName].getNode(data).checked// 如果当前节点被选中,则遍历下级子节点并选中,如果当前节点取消选中,则遍历下级节点并取消if (isChecked) {// 判断该节点是否有下级节点,如果有那么遍历设置下级节点为选中data.children && data.children.length > 0 && setChildreChecked(data.children, true)} else {// 如果节点取消选中,则取消该节点下的子节点选中data.children && data.children.length > 0 && setChildreChecked(data.children, false)}function setChildreChecked (node, isChecked) {node.forEach(item => {item.children && item.children.length > 0 && setChildreChecked(item.children, isChecked)// 修改勾选状态_this.$refs[treeName].setChecked(item.name, isChecked)})}},checkChange (data, checked, indeterminate) {let _this = this;// console.log(data, checked, indeterminate);// 选中全部子节点,父节点也默认选中,但是子节点再次取消勾选或者全部子节点取消勾选也不会影响父节点勾选状态let checkNode = _this.$refs.tree.getNode(data)//获取当前节点// 勾选部分子节点,父节点变为半选状态if (checkNode.parent && checkNode.parent.childNodes.some(ele => ele.checked)) {checkNode.parent.indeterminate = true}// 勾选全部子节点,父节点变为全选状态if (checkNode.parent && checkNode.parent.childNodes.every(ele => ele.checked)) {checkNode.parent.checked = truecheckNode.parent.indeterminate = false}// 如果取消所有第二节点的勾选状态,则第一层父节点也取消勾选if (checkNode.level == 2 && checkNode.parent.childNodes.every(ele => !ele.checked)) {checkNode.parent.checked = falsecheckNode.parent.indeterminate = false}},

这篇关于element树形控件(tree)实现父与子关联,子与父不关联;手动设置半选状态的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/234377

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

hdu1011(背包树形DP)

没有完全理解这题, m个人,攻打一个map,map的入口是1,在攻打某个结点之前要先攻打其他一个结点 dp[i][j]表示m个人攻打以第i个结点为根节点的子树得到的最优解 状态转移dp[i][ j ] = max(dp[i][j], dp[i][k]+dp[t][j-k]),其中t是i结点的子节点 代码如下: #include<iostream>#include<algorithm

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、