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

  • vivox70pro+怎么给微信加密(vivox70pro怎么给别的手机充电)

    vivox70pro+怎么给微信加密(vivox70pro怎么给别的手机充电)

  • oppo手机纯净模式怎么关闭(oppo手机纯净模式怎么开启)

    oppo手机纯净模式怎么关闭(oppo手机纯净模式怎么开启)

  • 手机右上角出现n什么意思(手机右上角出现电话打叉是什么意思)

    手机右上角出现n什么意思(手机右上角出现电话打叉是什么意思)

  • 为什么微信的聊天记录自动没了(为什么微信的聊天背景图片会很模糊)

    为什么微信的聊天记录自动没了(为什么微信的聊天背景图片会很模糊)

  • 磁盘清理一直不结束(磁盘清理没反应)

    磁盘清理一直不结束(磁盘清理没反应)

  • vivos6有耳机吗(vivos6手机有耳机吗)

    vivos6有耳机吗(vivos6手机有耳机吗)

  • 双屏收银机外屏不显示(双屏收银机外屏怎么设置)

    双屏收银机外屏不显示(双屏收银机外屏怎么设置)

  • 手机坐公交怎么刷卡(手机坐公交怎么刷)

    手机坐公交怎么刷卡(手机坐公交怎么刷)

  • 电瓶车充电先插电池还是先插电源(电瓶车正确充电方法)

    电瓶车充电先插电池还是先插电源(电瓶车正确充电方法)

  • 探探怎么恢复聊天记录(探探如何找回聊天记录)

    探探怎么恢复聊天记录(探探如何找回聊天记录)

  • 微信互删后朋友圈点赞还有吗(微信互删后朋友圈评论多久消失)

    微信互删后朋友圈点赞还有吗(微信互删后朋友圈评论多久消失)

  • 常用的cd-rom是什么(cd rom是)

    常用的cd-rom是什么(cd rom是)

  • 怎么下载tiktok(ios怎么下载tiktok)

    怎么下载tiktok(ios怎么下载tiktok)

  • wps两个表格怎么合并(wps两个表格怎么快速切换)

    wps两个表格怎么合并(wps两个表格怎么快速切换)

  • 手机听筒坏了怎么办(手机 听筒坏了)

    手机听筒坏了怎么办(手机 听筒坏了)

  • 小米9pro怎么屏蔽应用推送通知(小米9pro5g屏幕)

    小米9pro怎么屏蔽应用推送通知(小米9pro5g屏幕)

  • wps表格标题如何加粗(wps表格标题如何搞两排)

    wps表格标题如何加粗(wps表格标题如何搞两排)

  • qq群主怎么设置管理员(QQ群主怎么设置禁言)

    qq群主怎么设置管理员(QQ群主怎么设置禁言)

  • oled与amoled的区别(oled和amoled的区别)

    oled与amoled的区别(oled和amoled的区别)

  • oppo相册私密照片在哪里看(oppo相册私密照片删除怎么恢复)

    oppo相册私密照片在哪里看(oppo相册私密照片删除怎么恢复)

  • cad多段线(cad多段线快捷键命令)

    cad多段线(cad多段线快捷键命令)

  • 开发植物识别app有何用途(植物识别软件哪个最好)

    开发植物识别app有何用途(植物识别软件哪个最好)

  • 解决 WebStorm 2022.3.x 无法识别 Element UI 2.15.11 新版本中的 el-xxx 标签问题(解决科学文化领域的矛盾应坚持的方针是)

    解决 WebStorm 2022.3.x 无法识别 Element UI 2.15.11 新版本中的 el-xxx 标签问题(解决科学文化领域的矛盾应坚持的方针是)

  • 以element ui为例分析前端各种弹窗和对话框的使用场景与区别(element ui的作用)

    以element ui为例分析前端各种弹窗和对话框的使用场景与区别(element ui的作用)

  • 子公司把利润给母公司怎么做账
  • 取得交易性金融资产投资收益为什么在借方
  • 小规模报企业所得税吗
  • 装水表财务是什么费用
  • 准予抵扣的进项税范围
  • 增值税进项税额转出的账务处理
  • 自产自用增值税组成计税价格
  • 应纳税额计算举例
  • 开租金发票可以提前开的吗?
  • 代收水电费如何开票商品分类编码
  • 服务费发票怎么做分录
  • 为什么增值税发票综合服务平台进不去
  • 采购比价流程图
  • 上个月的费用这个月开发票怎么做账
  • 企业发生的以旧换新业务应该按照什么处理
  • 汇算清缴前可以更改去年的账吗
  • 增值税即征即退会计处理
  • 长期待摊费用多少钱
  • 不是公户付的款开发票可以做账吗
  • 1697509550
  • 收取拆迁补偿费会计分录
  • 股东分红是看未交税吗
  • 积分抵现金活动怎么做
  • 普票被退回如何处理
  • 企业所得税汇算清缴操作流程
  • win7为什么这么多人用
  • 事业单位基建账并入大账规定
  • 如何设置两台路由器连接
  • js循环有哪些
  • 金融机构借款利率最新规定
  • 固定资产与固定资产净值
  • php的序列化操作生成的哪种格式
  • 微信收款要求绑定银行卡怎么办
  • zenity命令 显示图形框
  • php session_id
  • 一般贸易和进料加工退税的区别
  • java8 (jdk 1.8) 新特性——Lambda
  • 出租车发票可以重新打印吗
  • sql2000管理工具
  • mysql开启事务语句
  • 股东转让股权公司需要审查
  • 鸡蛋的发票
  • 企业非正常损失如何处理
  • 结转本年利润要算期初余额吗
  • 进项留底是什么科目
  • 长期股权投资会计实训心得
  • 高新技术企业奖励政策
  • 工程款抵房款什么意思
  • 企业代扣个人社保最新会计处理
  • 商业汇票到期无法兑现
  • 影响折旧的因素有哪三个方面
  • 应付账款的主要风险点
  • 捐赠利得计入资产成本吗
  • 简述公司利润分配的程序
  • 发票开错了记账凭证如何做?
  • sql server 3417错误
  • 类似wps office的手机软件
  • Win10预览版镜像
  • win10禁用系统uac
  • linux make命令怎么用
  • win8系统忘记电脑开机密码怎么办
  • ubuntu下安装deb文件
  • mac配置selenium
  • win7 设置
  • win7如何删除系统启动项
  • win7玩英雄联盟卡顿怎么解决
  • cocos creator js ts
  • fragment的replace方法
  • ai人工智能python
  • jquery设置自定义属性
  • js实现滑动开关功能
  • android设计模式的应用场景
  • unity做app
  • jquery unload
  • json初学
  • 国家税务总局2012年20号公告
  • 运输专票怎么开发票
  • 手机陌陌卸载还有记录吗
  • 工商税务登记流程视频
  • 税收超额负担图解
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设