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

  • iwatch7用什么充电头(apple watch 7充电功率)

    iwatch7用什么充电头(apple watch 7充电功率)

  • 趣头条怎么提现(趣头条怎么提现不出来钱在什么地方)

    趣头条怎么提现(趣头条怎么提现不出来钱在什么地方)

  • 别人的airpods怎么连接到自己的手机(别人的airpods怎么连接)

    别人的airpods怎么连接到自己的手机(别人的airpods怎么连接)

  • 如何下载小红书视频(如何下载小红书的视频无水印)

    如何下载小红书视频(如何下载小红书的视频无水印)

  • 淘宝退货售后卡怎么填(淘宝退货售后卡怎么写)

    淘宝退货售后卡怎么填(淘宝退货售后卡怎么写)

  • 快手小店找不到了怎么回事(快手小店找不到基本工具)

    快手小店找不到了怎么回事(快手小店找不到基本工具)

  • vivo丢了手机如何确定手机位置(vivo手机丢了该怎么办)

    vivo丢了手机如何确定手机位置(vivo手机丢了该怎么办)

  • 钉钉重新提交作业老师知道吗(钉钉重新提交作业之前的还能看到吗)

    钉钉重新提交作业老师知道吗(钉钉重新提交作业之前的还能看到吗)

  • 小红书直播能看回放吗(小红书直播能看见在线吗)

    小红书直播能看回放吗(小红书直播能看见在线吗)

  • 拼多多红包助力最多能点多少次(拼多多红包助力网站)

    拼多多红包助力最多能点多少次(拼多多红包助力网站)

  • 音乐包和vip区别(音乐包和vip区别网易云)

    音乐包和vip区别(音乐包和vip区别网易云)

  • 修屏幕要多久(修手机屏幕大概需要多少钱)

    修屏幕要多久(修手机屏幕大概需要多少钱)

  • arttl00x是华为什么型号

    arttl00x是华为什么型号

  • realme Q怎么用音量键拍照(realmex怎么读语音)

    realme Q怎么用音量键拍照(realmex怎么读语音)

  • huaweinova5参数(华为nova5参数表)

    huaweinova5参数(华为nova5参数表)

  • 安卓怎么查电池健康度(安卓怎么查电池容量多少)

    安卓怎么查电池健康度(安卓怎么查电池容量多少)

  • 淘集集二维码在哪里看(淘集集东西能买吗)

    淘集集二维码在哪里看(淘集集东西能买吗)

  • iphone设置隐私视频(ios14设置隐私视频)

    iphone设置隐私视频(ios14设置隐私视频)

  • 抖音的增高特效在哪(抖音拍摄增高在哪设置?)

    抖音的增高特效在哪(抖音拍摄增高在哪设置?)

  • iphonex原装屏幕鉴定(iphonex原装屏幕价格)

    iphonex原装屏幕鉴定(iphonex原装屏幕价格)

  • 为什么微信笔记发送失败(为什么微信笔记里的图片一直加载不出来)

    为什么微信笔记发送失败(为什么微信笔记里的图片一直加载不出来)

  • 微信登录的接口(微信登录接口购买)

    微信登录的接口(微信登录接口购买)

  • Spring Boot 3.0系列【19】核心特性篇之自定义Starter启动器(spring boot 2.3.0)

    Spring Boot 3.0系列【19】核心特性篇之自定义Starter启动器(spring boot 2.3.0)

  • 关于古老的jsp页面的知识汇总(超详细)

    关于古老的jsp页面的知识汇总(超详细)

  • 《Python项目开发实战》PDF高清版下载(python项目开发案例集锦pdf百度网盘)

    《Python项目开发实战》PDF高清版下载(python项目开发案例集锦pdf百度网盘)

  • 应交增值税一般纳税人的账怎么做
  • 去年多计提的工资今年直接冲掉当期费用,不调增可以吗
  • 企业所得税从业人数怎么填,依据什么填写
  • 个人所得税的税目分多少种
  • 在建工程贷款利息分录
  • 纳税人出租不动产预缴税款
  • 现金折扣冲减销售收入冲销项税吗
  • 保险金扣税吗
  • 公益机构可以收费吗
  • 取得成本发票
  • 你觉得微信提现收费合理吗?
  • 增值税销项税如何进行处理,有哪些种情况
  • 企业对外借款是怎么规定的
  • 发票丢失可以冲销吗
  • 试车要给钱吗
  • 计提固定资产减值准备属于什么支出
  • 增值税如何填报
  • 公车私用情形有哪些
  • 开具红字发票后又开了蓝字发票 怎么入账
  • 发票查询发票代码有误
  • 1697509422
  • windows10如何开启vt
  • 购买保本理财产品
  • 外贸综合服务企业代办退税
  • cpu天梯图,最新
  • 0x0000001e蓝屏代码的含义
  • php和py
  • win10 1909无法连接到这个网络
  • 字体文件夹在哪
  • 企业清算所得税如何计算
  • uni-app list
  • 森林抗锯齿
  • 转让土地需要办什么手续
  • 房产土地税计提新规
  • 高新补贴收入是否可以作为不征税收入
  • 清洁费用是属于什么科目
  • rgbt目标跟踪
  • ROS2+cartographer+激光雷达+IMU里程计数据融合(robot_locazation) 建图
  • 纳入资本公积
  • 采购员出差预借差旅费300元
  • 银行历年账单怎么查
  • vue中webpack用来干啥
  • css 入门
  • 帐没做完怎么报增值税
  • mysql profiles
  • phpcms使用教程
  • 公司购买基金入什么科目
  • 固定资产清理净损益怎么计算出来的
  • 销售收入和销售收入净额的区别
  • 以房租入股公司怎么交税
  • 同一控制下企业合并发生的审计费用计入
  • 合营企业和联营企业的概念
  • 固定资产清理的借贷方向
  • 企业与企业之间通过互联网进行产品
  • 什么情况可以作为证人
  • 固定资产正常报废与非正常报废的会计处理基本相同
  • 计量差错引起的原材料盘亏
  • 装修费用不摊销怎么入账
  • 餐费补贴属于工资还是福利费
  • 金税盘可以申请发票吗
  • 房地产开发企业建造的商品房,在出售前
  • 卖掉公司旧办公用品怎么入账
  • 房地产开发企业增值税怎么算
  • sql如何学
  • 主板bios恢复出厂默认设置方法
  • xpkw
  • ubuntu 16:9
  • win8命令提示符管理员怎么打开
  • win7如何创建新桌面
  • win7如何限制网速
  • cocos 2d x
  • linux删除文件语句
  • 字符串查找子串
  • python jsondecodeerror异常捕获
  • js中调用java
  • 解决js请求服务问题
  • 吉林税务网上办事大厅
  • 韩国快递关税
  • 江西税务局
  • 内蒙古城镇土地使用税税率表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设