位置: 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) 建图

  • iphone主副卡怎么切换(iphone主副卡怎么安装)

    iphone主副卡怎么切换(iphone主副卡怎么安装)

  • iphone怎么限制别人连热点(苹果怎么限制别人用自己wifi的速度)

    iphone怎么限制别人连热点(苹果怎么限制别人用自己wifi的速度)

  • 华为荣耀20的处理器是什么处理器(华为荣耀20的处理器是多少)

    华为荣耀20的处理器是什么处理器(华为荣耀20的处理器是多少)

  • 锐龙r5 2600相当于i几(锐龙r52600相当于i5的哪一款)

    锐龙r5 2600相当于i几(锐龙r52600相当于i5的哪一款)

  • mate30pro的尺寸(华为mate30pro尺寸大小)

    mate30pro的尺寸(华为mate30pro尺寸大小)

  • 微信群二维码可以多少个人扫(微信群二维码可以长期有效吗)

    微信群二维码可以多少个人扫(微信群二维码可以长期有效吗)

  • 华为手机怎么换机(华为手机怎么换卡怎么取卡)

    华为手机怎么换机(华为手机怎么换卡怎么取卡)

  • qq号码刚注销怎么恢复(qq号注销了怎么办)

    qq号码刚注销怎么恢复(qq号注销了怎么办)

  • 智慧团建系统终止是什么意思(智慧团建系统终止怎么转入)

    智慧团建系统终止是什么意思(智慧团建系统终止怎么转入)

  • 话费欠费不交3个月会怎样(话费欠费不交会越欠越多吗)

    话费欠费不交3个月会怎样(话费欠费不交会越欠越多吗)

  • 华为nova7什么时候发布(华为nova7什么时候升级鸿蒙3.0)

    华为nova7什么时候发布(华为nova7什么时候升级鸿蒙3.0)

  • 抖音发消息已送达什么意思(抖音发消息已送达与未读)

    抖音发消息已送达什么意思(抖音发消息已送达与未读)

  • 抖音删评论会降权吗(抖音里删除评论会降低点击率吗)

    抖音删评论会降权吗(抖音里删除评论会降低点击率吗)

  • 电脑出现error1962怎么解决(电脑出现error1962:nooperating)

    电脑出现error1962怎么解决(电脑出现error1962:nooperating)

  • 爱奇艺的学生会员和黄金会员有什么区别(爱奇艺的学生会员在哪里开)

    爱奇艺的学生会员和黄金会员有什么区别(爱奇艺的学生会员在哪里开)

  • 当乐账号容易被找回么(当乐账号解封)

    当乐账号容易被找回么(当乐账号解封)

  • 微信公众号名字怎么改不了(微信公众号名字审核不通过怎么办)

    微信公众号名字怎么改不了(微信公众号名字审核不通过怎么办)

  • 怎么设计宣传单(如何设计宣传单吸引人)

    怎么设计宣传单(如何设计宣传单吸引人)

  • iphone7mn开头是国航吗(苹果7手机型号mn开头)

    iphone7mn开头是国航吗(苹果7手机型号mn开头)

  • 微信星标好友的含义(微信星标好友的意思)

    微信星标好友的含义(微信星标好友的意思)

  • 拼多多换货流程(拼多多换货流程快递怎么弄)

    拼多多换货流程(拼多多换货流程快递怎么弄)

  • iqoo怎么开启性能模式(iqoo手机性能模式怎么开)

    iqoo怎么开启性能模式(iqoo手机性能模式怎么开)

  • 红米note8pro是什么屏幕(红米note8pro怎么样?)

    红米note8pro是什么屏幕(红米note8pro怎么样?)

  • 文档部件域的含义(word2010文档部件域可以做什么)

    文档部件域的含义(word2010文档部件域可以做什么)

  • iphone xs max屏幕失灵(iphonexsmax的屏幕刷新率)

    iphone xs max屏幕失灵(iphonexsmax的屏幕刷新率)

  • qq音乐动图图标可以删吗(qq音乐动图图标重复文件)

    qq音乐动图图标可以删吗(qq音乐动图图标重复文件)

  • ipad上的siri怎么关闭(ipad上的siri怎么用)

    ipad上的siri怎么关闭(ipad上的siri怎么用)

  • mblu是什么牌子的手机(mbl属于什么档次)

    mblu是什么牌子的手机(mbl属于什么档次)

  • iwatch4gps能接电话么(iwatchgps可以连接wifi吗)

    iwatch4gps能接电话么(iwatchgps可以连接wifi吗)

  • css深度选择器deep(css选择器nth)

    css深度选择器deep(css选择器nth)

  • python输入成绩求平均分(python输入三科成绩)

    python输入成绩求平均分(python输入三科成绩)

  • 应纳税所得额是什么意思
  • 实习生个人所得税需要申报吗
  • 个体户核定双定户是否可以年度汇算清缴
  • 社会团体财政票据管理制度
  • 多项固定资产能否合并入账
  • 服务合同需要征税吗
  • 递延所得税当期发生额
  • 政策减免是什么意思
  • 买酒 专票
  • 开了增值税发票不确认收入可以吗
  • 购买固定资产增值税可以抵扣
  • 金税三期房产税源信息更改后
  • 建筑企业收到的成本发票可以直接进主营业务成本吗
  • 预收账款抵扣怎么做分录
  • 发票红冲和作废一样吗
  • 个人所得税适合月度税率表有哪些
  • 汇兑结算包括
  • 企业所得税汇算清缴表
  • 如何查看windows密钥时间
  • 如何正确使用储存卡
  • 怎么做增值税
  • win8.1技巧
  • 餐费专用发票怎么抵扣
  • uni app
  • 新win10浏览器
  • 上市公司发行股票是好还是坏
  • mac键盘快捷键设置
  • 从价计征房产税如何计算
  • php魔术函数
  • 转让存货属于什么收入
  • 差旅费报销会计处理
  • anjedi编辑器
  • 发票认证相符什么意思
  • 应税货物及劳务无法录入
  • php post数据
  • php怎么上传图片并保存到数据库
  • 错误日志怎么修复
  • 建筑行业预交增值税怎么结转
  • 加工行业增值税负率一般控制在多少?
  • 员工的交通费发票可以报销嘛
  • 回扣没拿到也算违法吗
  • python2.7 协程
  • 递延所得税资产和递延所得税负债
  • 动产什么时候取得所有权
  • 小规模纳税人如何申报增值税
  • 法人股东 分红
  • 生产部门使用的无形资产摊销
  • 同一控制下合并冲减资本公积
  • 初级职称需要提交什么资料
  • 小规模企业申报表填写
  • 出口退税指的是什么意思
  • 亏损企业对外捐赠的税前扣除
  • 固定资产处置当月需要计提折旧吗
  • 从基本存款账户划款3万元 向开户银行转帐
  • 固定资产计提完了怎么处理
  • 售楼部装修费计入什么科目
  • 小规模纳税人哪里可以查
  • 接受投资者投入的资产
  • 私营公司商业汇票怎么开
  • 企业外购的固定资产应该怎样进行会计核算
  • centos安装NVIDIA驱动
  • 电脑如何将耳机模式换扬声器
  • win10光驱无法识别
  • 电脑预读文件
  • win8.1拨号上网
  • setcontentview报错
  • linux find命令的使用
  • css中的auto
  • 简单谈谈对电信的认识
  • 手机gpu过度绘制
  • 字符串查找子串
  • shell 字符串trim
  • javascriptcsdn
  • python selectfrommodel
  • javascript面向对象编程
  • jquery遍历li
  • 如何退契税网上申请
  • 印花税为什么不计入资产成本
  • 湖北省电子税务局
  • 实名办税有什么作用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设