位置: IT常识 - 正文

Element UI级联选择器 多选模式下,实现同一父级下最多只能选中一个子级(elementui级联选择器清空方法)

编辑:rootadmin
Element UI级联选择器 多选模式下,实现同一父级下最多只能选中一个子级

推荐整理分享Element UI级联选择器 多选模式下,实现同一父级下最多只能选中一个子级(elementui级联选择器清空方法),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:elementui级联选择器获取当前选中的值,elementui级联选择器获取当前选中的值,element UI级联选择左侧,elementui级联选择器获取当前选中的值,elementui级联选择器清空方法,elementui级联选择器 数据过大,element UI级联选择左侧,elementui级联选择器,内容如对您有帮助,希望把文章链接给更多的朋友!

这个需求有点多选与单选结合的意思,同一父级下的子节点单选,又可以选择多个不同父级下的节点。这里以两级为例,实现一个在多选模式下,同一父级下最多只能选中一个子级的级联选择器。

1、隐藏父级节点处的CheckBox

多选模式下可以通过勾选父级一键选中所有的子级,而每个父级下可能有多个子级,也可能只有一个,起初我想的是根据本次选择选中的个数分类讨论,但讨论起来比较繁琐,所以最后决定直接把父级的checkbox隐藏掉,不让用户直接勾选父级,减少了很多不必要的麻烦。

.hide { .el-cascader-menu:first-of-type { .el-cascader-node { .el-checkbox { display: none; } } }}

这里需要注意的一点是hide类名必须使用级联选择器中的popper-class来添加自定义浮层类名的。

 2、对选中的项进行筛选限制,先找到本次新增的项,和新增前的值进行对比,看是否存在与本次新增的项同属于一个父级的,如果存在则删除之前已经存在的那一项,留下本次新增的。

这里的解决花费了我很多时间,因为一开始想着直接操作级联选择器绑定值,删除掉不要的那一项就可以了,但问题出现了。绑定的值确实达到了我想要的效果(即删除之前已经存在的那一项,留下本次新增的),但级联面板中右侧的部分(即子节点部分),会自动刷新跳转到第一个父级下的子级面板,用户体验差,尝试解决,没解决掉。。。

最后,选择从另外一个角度来实现,如果存在与本次新增的项同属于一个父级的,则直接通过js触发点击事件,取消勾选之前已经存在的那一项。

Element UI级联选择器 多选模式下,实现同一父级下最多只能选中一个子级(elementui级联选择器清空方法)

有了思路以后就可以一步一步来实现了。

首先找到本次新增的这一项,由于组件库文档中级联选择器这一块并没有提供相关的办法获取到最新选择的一项,只能拿到已选择的所有值,并且级联选择器新增的项并不是直接push到绑定值的末尾,而是按选项值在页面上展示的顺序添加的,所以只能手动去对比查找,需要定义一个preValue数组来存储上一次的值。

let newIndex;let i = 0, j = 0;while (i < val.length && j < this.preValue.length) { if (val[i][0] === this.preValue[j][0] && val[i][1] === this.preValue[j][1]) { i++; j++; } else { //添加在中间的情况 newIndex = i; break; }}//添加在末尾的情况if (j === this.preValue.length) { newIndex = i;}

找到新增项后,再去对比在此之前是否添加过于新增项同一父级下的其他子级。

let delIndex = val.findIndex((item, index) => index !== newIndex && item[0] === val[newIndex][0]);

如果存在的话,接下来就需要去触发相应的点击事件取消这一项的勾选。

我们先来观察一下html结构,右侧面板下的各个li标签的id值其实就是右侧面板id值加上:'-'+index,因此我们只需要拿到右侧面板id值就能知道对应选项的id值,再触发li标签的孩子标签中的checkbox的点击事件就可以了。

 右侧面板id通过级联选择器的引用可以拿到,另外需要求得取消勾选选项的index,通过与级联选择器选项值对比得到。

let cancelIndex;for (let i = 0; i < this.options.length; i++) { if (this.options[i].value === val[delIndex][0]) { for (let j = 0; j < this.options[i].children.length; j++) { if (this.options[i].children[j].value === val[delIndex][1]) { cancelIndex = j; break; } } break; }}

获取id值。

this.$nextTick(() => { let panelId = this.$refs.cascade.panel.$refs.menu[1].$el.id; //其中menu[1]表示右侧的面板 menu[0]即为左侧的面板 let liId = document.getElementById(panelId + '-' + cancelIndex); liId.children[0].click(); })

到这里就基本完成了这个需求,其实不难,但因为一开始自己的思路(直接删值)实现起来出现了问题,想着去解决花费了很多时间,也没解决掉,最后和同事讨论换一种思路很快就实现了,所以思路变通是非常重要的~

3、完整代码

<template> <div class='test'> <el-cascader class='cascader' :options='options' :props='props' clearable :popper-class="'hide'" @change='handleChange' ref='cascade' ></el-cascader> </div></template><script>export default { name: 'Cascader', data() { return { props: { multiple: true, expandTrigger: 'click' }, options: [{ value: 1, label: '杭州', children: [{ value: 3, label: '西湖' }, { value: 4, label: '钱塘' }, { value: 7, label: '上城' }] }, { value: 2, label: '成都', children: [{ value: 5, label: '青羊' }, { value: 6, label: '武侯' }] }], preValue:[] } }, methods:{ handleChange(val){ if (this.preValue.length > 0 && val.length > this.preValue.length) { let newIndex; let i = 0, j = 0; while (i < val.length && j < this.preValue.length) { if (val[i][0] === this.preValue[j][0] && val[i][1] === this.preValue[j][1]) { i++; j++; } else { //添加在中间的情况 newIndex = i; break; } } //添加在末尾的情况 if (j === this.preValue.length) { newIndex = i; } let delIndex = val.findIndex((item, index) => index !== newIndex && item[0] === val[newIndex][0]); if (delIndex >= 0) { // 取消选择的节点 let cancelIndex; for (let i = 0; i < this.options.length; i++) { if (this.options[i].value === val[delIndex][0]) { for (let j = 0; j < this.options[i].children.length; j++) { if (this.options[i].children[j].value === val[delIndex][1]) { cancelIndex = j; break; } } break; } } this.$nextTick(() => { let panelId = this.$refs.cascade.panel.$refs.menu[1].$el.id; //其中menu[1]表示右侧的面板 menu[0]即为左侧的面板 let liId = document.getElementById(panelId + '-' + cancelIndex); liId.children[0].click(); }) val[delIndex] = ''; val = val.filter(item => item !== ''); } } this.preValue = val; } }};</script><style lang='less'>.test { text-align: center; margin-top: 200px; .title { display: block; margin-bottom: 20px; } .cascader { .el-input__inner { width: 362px; } .el-cascader__tags { display: flex; flex-wrap: nowrap; overflow-y: overlay; margin-left: 2px; } .el-cascader__tags::-webkit-scrollbar { width: 0; height: 3px; } /*定义滚动条轨道 内阴影+圆角*/ .el-cascader__tags::-webkit-scrollbar-track { background-color: rgba(186, 203, 227, 0.3); } /*定义滑块 内阴影+圆角*/ .el-cascader__tags::-webkit-scrollbar-thumb { background-color: #B3C2D7; } }}.hide { .el-cascader-menu:first-of-type { .el-cascader-node { .el-checkbox { display: none; } } }}</style>

如果大家有更好的解决办法或优化,欢迎评论区讨论~

本文链接地址:https://www.jiuchutong.com/zhishi/293093.html 转载请保留说明!

上一篇:微信小程序登录方法,授权登陆及获取微信用户手机号(微信小程序登录后端)

下一篇:ROS2+cartographer+激光雷达+IMU里程计数据融合(robot_locazation) 建图

  • 华为备忘录如何导入vivo手机(华为备忘录如何导入苹果新手机)

    华为备忘录如何导入vivo手机(华为备忘录如何导入苹果新手机)

  • 荣耀x10如何关闭开发者模式(荣耀x10如何关闭充电提示音)

    荣耀x10如何关闭开发者模式(荣耀x10如何关闭充电提示音)

  • 华为手机屏幕录制怎么弄(华为手机屏幕录制怎么没有声音)

    华为手机屏幕录制怎么弄(华为手机屏幕录制怎么没有声音)

  • 不同的网络应用服务使用不同的密码对吗(不同的网络应用程序)

    不同的网络应用服务使用不同的密码对吗(不同的网络应用程序)

  • 华为p40怎么录屏幕视频(华为p40怎么录屏没有白点)

    华为p40怎么录屏幕视频(华为p40怎么录屏没有白点)

  • 抖音聊天列表没有了(抖音聊天记录怎么不显示了)

    抖音聊天列表没有了(抖音聊天记录怎么不显示了)

  • wps功能是什么(华为路由器的wps功能是什么)

    wps功能是什么(华为路由器的wps功能是什么)

  • 戴尔电脑充不进电什么原因(戴尔电脑充不进去电指示灯橙色闪烁)

    戴尔电脑充不进电什么原因(戴尔电脑充不进去电指示灯橙色闪烁)

  • 被加好友过于频繁多久恢复(被加好友过于频繁多久能解除)

    被加好友过于频繁多久恢复(被加好友过于频繁多久能解除)

  • qq的消息提示怎么开启(qq消息提示在哪)

    qq的消息提示怎么开启(qq消息提示在哪)

  • 经常摔手机对手机有什么影响(经常摔手机对手机电池有影响吗)

    经常摔手机对手机有什么影响(经常摔手机对手机电池有影响吗)

  • 什么是中台系统(什么叫做中台)

    什么是中台系统(什么叫做中台)

  • 抖音号是怎么生成的(抖音号是怎么生出来的)

    抖音号是怎么生成的(抖音号是怎么生出来的)

  • vivo手机快充充电慢怎么办(vivo手机快充充电线)

    vivo手机快充充电慢怎么办(vivo手机快充充电线)

  • 怎样把视频保存到手机相册里(怎样把视频保存到图库)

    怎样把视频保存到手机相册里(怎样把视频保存到图库)

  • realmex2pro怎么设置自动息屏时间(realmex2pro90hz怎么打开)

    realmex2pro怎么设置自动息屏时间(realmex2pro90hz怎么打开)

  • word画线怎么画(Word画线怎么画)

    word画线怎么画(Word画线怎么画)

  • 抖音上热门一般多久(抖音上热门一般审核多久)

    抖音上热门一般多久(抖音上热门一般审核多久)

  • ipad怎么解除耳机模式(如何取消ipad耳机模式)

    ipad怎么解除耳机模式(如何取消ipad耳机模式)

  • 系统更新对手机有影响吗(系统更新对手机信号有影响吗)

    系统更新对手机有影响吗(系统更新对手机信号有影响吗)

  • 探探好友恢复列表在哪(探探的好友怎么恢复)

    探探好友恢复列表在哪(探探的好友怎么恢复)

  • 华为手机表情为什么显示不出来(华为手机表情在哪里打开)

    华为手机表情为什么显示不出来(华为手机表情在哪里打开)

  • 怎么关闭windows的安全警报(怎么关闭windows defender)

    怎么关闭windows的安全警报(怎么关闭windows defender)

  • WebSocket(websocket怎么读)

    WebSocket(websocket怎么读)

  • sensors命令  检测服务器硬件信息(sensor tester)

    sensors命令 检测服务器硬件信息(sensor tester)

  • 合集phpcms安全漏洞(php5.6漏洞)

    合集phpcms安全漏洞(php5.6漏洞)

  • 个税应纳税所得额是要上交的钱吗
  • 融资租赁本金和租金的区别
  • 税务局代个人开发票交什么税
  • 个体工商户每月需要申报个税吗
  • 对公的etc怎么绑定怎么充值
  • 本期金额和上期金额怎么填写
  • 2019小规模纳税人免征增值税政策
  • 购入材料过程中支付运费
  • 跨年冲减费用
  • 营改增后进项税额分摊
  • 基建账的年终结转
  • 土地罚款可以计入成本吗?
  • 企业认购普通股100万股作为交易性金融资产管理
  • 企业所得税退税的会计分录怎么做
  • 企业个人所得税逾期未申报怎么办
  • 关联关系的判定标准
  • 甲公司聘用乙为业务经理
  • 固定资产发生非正常损失相关题目
  • 开办费摊销时间税法规定
  • 建筑公司购买的材料计入什么科目
  • 增值税申报表中期初未缴税额指什么
  • 提前支付一年费用怎么算
  • 固定资产折旧金额影响因素
  • 劳务费个税计算方式
  • 合并财务报表中的负债和股东权益
  • 收到安监处罚款怎么处理
  • 贷款的钱转账了怎么办
  • 被辞退有补助金吗
  • gain_trickler_3202.exe 进程查询 gain_trickler_3202进程是什么文件
  • 债券的回购
  • 赤狐,荷兰 (© Wim Weenink/Minden Pictures)
  • php图片加水印实例分析
  • vue中的组件
  • vue3 响应式ui框架
  • 电子回单是什么样子
  • 应收票据应付票据合并抵消吗
  • 社保费和公积金一定要计提吗
  • 服务费减免税款怎么算
  • 沙箱支付宝app正式版
  • 年末需暂估已发生的费用吗
  • 福利费用属于哪个部门
  • 一般纳税人之外还有什么
  • 税务多措并举
  • 融资租赁租出的固定资产账务处理
  • 应交税费属于什么负债
  • 支付技术研究开发费
  • 计提商业承兑汇票会计分录怎么写
  • 建账要求
  • 银行贷款利息支出税前扣除标准
  • 固定资产的维修计入什么科目
  • 培训发票能抵扣吗
  • 律师事务所日语助理
  • 资本公积可用于弥补企业亏损
  • 外地预缴需要缴纳印花税吗
  • 营改增后不动产发票怎么开
  • 公对公转账多久能到账
  • 如何设置生产成本总账表格
  • 数据库sql server
  • mysql清空数据表怎么恢复
  • sqlserver导出mysql
  • xp系统百度
  • linux中git命令
  • win2000系统安装教程
  • win10提示测试模式
  • ora01804怎么解决windows
  • win8分屏快捷键
  • vmware怎么配置网络
  • win7系统IE浏览器怎么去掉360导航
  • 深入理解中国式现代化
  • python pip版本更新
  • js的document.getelembyid
  • 批处理隐藏盘符
  • 有几种导航
  • jQuery插件是什么
  • python连接mq
  • python中的异常处理有哪些
  • js模拟点击事件onclick
  • 新疆税务局电子
  • uk在哪里看开票截止日期
  • 上海川沙十八铺市场
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设