解决element-ui里的下拉多选框 el-select 时,默认值不可删除问题


Posted in Javascript onAugust 14, 2020

这是一个项目中常见的需求,el-select 为下拉多选,默认值不可删除,或者指定值不可删除。

实现效果:

解决element-ui里的下拉多选框 el-select 时,默认值不可删除问题

el-select 如下源码中 tag closable 属性为 el-select 的 disabled 属性,所有明显不支持。

解决element-ui里的下拉多选框 el-select 时,默认值不可删除问题

解决思路(从el-select 的角度来考虑,其他组件组合的情况暂不考虑)

想要实现某些选项是不删除,1、需要tag 不可删除,2、options 不可选择

options 不可选择很好实现,只需要给一个disabled属性。tag 不可删除才是关键。下面是我几种解决思路。

1、 watch 进行监听,当操作不可删除的选项时,el-select 绑定的值中 将之前删除的选项重新添加到原来的位置。达到不可删除的效果。(这种方法虽然可以实现,但是tag上还是会有 “x” 会给用户一种误导)

2、使用样式,定位到 tag中,将icon “x” 设置 display:none; 将关闭 按钮隐藏,达到不可删除的效果。

3、复制一份 element-ui 中 el-select 源码 进行少量的修改,给 tag 添加一个 closagle 的属性。达到可控的效果。(这种方式增加了开发维护成本,当项目中 element-ui 升级版本的时候,需要重新对源码赋值一份进行修改)

4、使用 derictive 给 element-ui 中 tag 添加样式,实际上是对思路二的一种实现。

思路是这么一个思路,也对思路1和4进行了实现。但是综合考虑下,还是针对思路4做下记录,感觉有一点点复用意义。其它的参考价值不大。代码如下定义了一个全局的指令,也可以定义在组件里面。

// index.vue
 
 <el-select v-model="ruleForm.ability" multiple placeholder="请选择">
	<el-option
	 v-for="(item, index) in abilityOptions"
	 :key="index"
	 :label="`${item.abilityNameZh}(${item.abilityId})`"
	 :disabled="item.required === 1"
	 :value="item.abilityId">
	</el-option>
 </el-select>
// main.js
 
Vue.directive('defaultSelect', {
 componentUpdated (el, bindings, vnode) {
  // values v-model 绑定值
  // options 下拉选项
  // prop 对应 options 中 的 value 属性
  // defaultProp 默认值判断属性 
  // defaultValue 默认值判断值
  const [values, options, prop, defaultProp, defaultValue] = bindings.value
  // 需要隐藏的标签索引
  const indexs = []
  const tempData = values.map(a => options.find(op => op[prop] === a))
  tempData.forEach((a, index) => {
   if (a[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')
    }
   })
  }
  // 设置样式 隐藏close icon
  const tags = el.querySelectorAll('.el-tag__close')
  if (tags.length === 0) {
   // 初始化tags为空处理
   setTimeout(() => {
    const tagTemp = el.querySelectorAll('.el-tag__close')
    dealStyle(tagTemp)
   })
  } else {
   dealStyle(tags)
  }
 }
})
// style.css 
.none { display: none; }

补充知识:vue+elementUI+select 选中多个值,我要删除其中的一两个 方法如下

我就废话不多说了,大家还是直接看代码吧~

<el-select value-key="moduleCode"
      multiple filterable
      allow-create default-first-option
      @remove-tag='removeTag'
      v-model="ruleForm.module3" placeholder="请选择权限分类" style="width: 240px">
 <el-option v-for="item in level3" :value="item" :label="item.moduleName" :key="item.moduleCode"></el-option>
</el-select>
methods:{

removeTag(key){
 console.log(key);//获取option中item
}
}

以上这篇解决element-ui里的下拉多选框 el-select 时,默认值不可删除问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
使用jquery为table动态添加行的实现代码
Mar 30 Javascript
探讨jQuery的ajax使用场景(c#)
Dec 03 Javascript
优化Node.js Web应用运行速度的10个技巧
Sep 03 Javascript
jquery 获取 outerHtml 包含当前节点本身的代码
Oct 30 Javascript
js的toUpperCase方法用法实例
Jan 27 Javascript
JavaScript实现网页对象拖放功能的方法
Apr 15 Javascript
JavaScript操作XML/HTML比较常用的对象属性集锦
Oct 30 Javascript
Android中Okhttp3实现上传多张图片同时传递参数
Feb 18 Javascript
selenium 与 chrome 进行qq登录并发邮件操作实例详解
Apr 06 Javascript
React组件refs的使用详解
Feb 09 Javascript
vue的for循环使用方法
Feb 12 Javascript
layui table 表格上添加日期控件的两种方法
Sep 28 Javascript
Vue + Element-ui的下拉框el-select获取额外参数详解
Aug 14 #Javascript
vue在App.vue文件中监听路由变化刷新页面操作
Aug 14 #Javascript
解决vue项目中某一页面不想引用公共组件app.vue的问题
Aug 14 #Javascript
在vue中封装方法以及多处引用该方法详解
Aug 14 #Javascript
JS+css3实现幻灯片轮播图
Aug 14 #Javascript
浅谈vue获得后台数据无法显示到table上面的坑
Aug 13 #Javascript
vue 解决data中定义图片相对路径页面不显示的问题
Aug 13 #Javascript
You might like
PHP中CURL的CURLOPT_POSTFIELDS参数使用细节
2014/03/17 PHP
CI框架Session.php源码分析
2014/11/03 PHP
ucenter通信原理分析
2015/01/09 PHP
php 获取文件行数的方法总结
2016/10/11 PHP
php实现博客,论坛图片防盗链的方法
2016/10/15 PHP
Ubuntu 16.04中Laravel5.4升级到5.6的步骤
2018/12/07 PHP
优化javascript的执行效率一些方法总结
2013/12/25 Javascript
javascript实现十秒钟后注册按钮可点击的方法
2015/05/13 Javascript
jQuery+CSS3+Html5实现弹出层效果实例代码(附源码下载)
2016/05/16 Javascript
无缝滚动的简单实现代码(推荐)
2016/06/07 Javascript
JS把内容动态插入到DIV的实现方法
2016/07/19 Javascript
JS Canvas定时器模拟动态加载动画
2016/09/17 Javascript
jQuery基于排序功能实现上移、下移的方法
2016/11/26 Javascript
VUE开发一个图片轮播的组件示例代码
2017/03/06 Javascript
JS原生轮播图的简单实现(推荐)
2017/07/22 Javascript
微信小程序中setInterval的使用方法
2017/09/29 Javascript
ES6 迭代器与可迭代对象的实现
2019/02/11 Javascript
微信小程序 组件的外部样式externalClasses使用详解
2019/09/06 Javascript
Python装饰器基础详解
2016/03/09 Python
python简单线程和协程学习心得(分享)
2017/06/14 Python
python3.4用循环往mysql5.7中写数据并输出的实现方法
2017/06/20 Python
Python读csv文件去掉一列后再写入新的文件实例
2017/12/28 Python
Python 数值区间处理_对interval 库的快速入门详解
2018/11/16 Python
Python可迭代对象操作示例
2019/05/07 Python
学习和使用python的13个理由
2019/07/30 Python
对Django中内置的User模型实例详解
2019/08/16 Python
基于python实现把图片转换成素描
2019/11/13 Python
Python生成器常见问题及解决方案
2020/03/21 Python
使用Python将Exception异常错误堆栈信息写入日志文件
2020/04/08 Python
pytho matplotlib工具栏源码探析一之禁用工具栏、默认工具栏和工具栏管理器三种模式的差异
2021/02/25 Python
盛大笔试题
2016/11/05 面试题
实习护士自我鉴定
2013/10/13 职场文书
电气自动化专业职业规划范文
2014/02/16 职场文书
《红军不怕远征难》教学反思
2014/04/14 职场文书
斗罗大陆八大特殊魂兽,龙族始祖排榜首,第五最残忍(翠魔鸟)
2022/03/18 国漫
Spring中的@Transactional的工作原理
2022/06/05 Java/Android