当前位置: 首页 > news >正文

el-select下拉多选框 el-select 设置默认值不可删除功能

Element3.0+vue3.0 el-select下拉多选框 el-select 设置默认值不可删除功能

Element-UI是一款广泛使用的Vue.js组件库,其中El-Select下拉多选框组件在实际项目开发中经常被使用。然而,在Element 3.0版本中,El-Select下拉多选框默认值可被删除,这可能会导致一些意外情况。本文将介绍如何解决这个问题,实现El-Select下拉多选框设置默认值不可删除的功能。

在这里插入图片描述

场景

假设我们正在开发一个商品筛选页面,在商品状态的多选筛选条件中,有一个"默认"选项,用于选择默认状态的商品。我们希望用户无法取消选择“默认”选项,以确保至少有一个状态被选中。

功能分析

  • 首先 el-select是不支持这个功能的 最多可以禁止el-option 的 disabled属性
    源码:
    在这里插入图片描述
  • 所以需要我们更改一下代码 当el-option的disabled为true的时候 把select-tag-close-none属性为none
    这样就实现了

实战在mian.js中放入以下代码就可以了

亿点小知识:vue3.0中是 app.directive 在 vue2.0中是 Vue
vue3.0中
在这里插入图片描述

app.directive("defaultSelect", {componentUpdated(el, bindings) {const [values, options, prop, defaultProp, defaultValue] = bindings.value;const indexs = [];const tempData = values.map(item => options.find(op => op[prop] === item));tempData.forEach((item, index) => {if (item[defaultProp] === defaultValue) {indexs.push(index);}});const dealStyle = function(tags) {tags.forEach((el, index) => {if (indexs.includes(index) && ![...el.classList].includes("select-tag-close-none")) {el.classList.add("none");}});};const tags = el.querySelectorAll(".el-tag__close");if (tags.length === 0) {setTimeout(() => {const tagTemp = el.querySelectorAll(".el-tag__close");dealStyle(tagTemp);});} else {dealStyle(tags);}}
});

在这里插入图片描述
以上就是el-select下拉多选框 el-select 设置默认值不可删除功能感谢大家的阅读
如碰到其他的问题 可以私下我 一起探讨学习
如果对你有所帮助还请 点赞 收藏谢谢~!
关注收藏博客 作者会持续更新…

http://www.lryc.cn/news/155043.html

相关文章:

  • Jetsonnano B01 笔记1:基础理解—网络配置—远程连接
  • Ubuntu系统信息查看指南:了解你的操作系统
  • 【STM32】学习笔记-SPI通信
  • 解决vue项目首行报红( ESLint 配置)和新建的vue文件首行报红问题
  • Linux 调试技术 Kprobe
  • 一文了解评估 K8s 原生存储产品需要关注的关键能力
  • linux免密登录报错 Bad owner or permissions on /etc/ssh/ssh_config.d/05-redhat.conf
  • Kafka常用参数
  • NFT Insider#105:The Sandbox即将参加韩国区块链周,YGG的声誉和进步(RAP)将引领玩家晋升到下一层级
  • TCP socket error (The proxy type is invalid for this operation).
  • 根据需求生成一个Vue模块的类图示例
  • C# 类class、继承、多态性、运算符重载,相关练习题
  • Mysql高级(进阶)SQL语句
  • java八股文面试[JVM]——JVM性能优化
  • 联发科MTK6762/MT6762核心板_安卓主板小尺寸低功耗4G智能模块
  • Redis未授权访问漏洞复现
  • 用深度强化学习来玩Flappy Bird
  • HTML5-4-表单
  • Nacos 开源版的使用测评
  • 【Linux】一些常见查看各种各样信息的命令
  • 51单片机DHT11温湿度控制系统仿真设计( proteus仿真+程序+原理图+报告+讲解视频)
  • 神仙级python入门教程(非常详细),从0到精通,从看这篇开始!
  • 详解4种类型的爬虫技术
  • QTday1基础
  • activiti 通过xml上传 直接部署模型
  • 算法题打卡day56-编辑距离 | 583. 两个字符串的删除操作、72. 编辑距离
  • SQL中的CASE WHEN语句:从基础到高级应用指南
  • 超时取消子线程任务
  • 模块化---common.js
  • VSCode下载、安装及配置、调试的一些过程理解