基于Element的组件改造的树形选择器(树形下拉框)


Posted in Javascript onFebruary 27, 2020

前言:由于做项目需要一个树形选择器,项目用的也是element-ui框架,然而它自带的选择器组件没有树形选项,又不想引入其他的框架组件,于是自己利用el-select和el-tree改造了一个,感觉还挺好用的,就封装成了一个组件,如下图:

element-ui的el-select组件的选项只能是列表形式:

基于Element的组件改造的树形选择器(树形下拉框)

 改造后的树形选择器:

基于Element的组件改造的树形选择器(树形下拉框)

简介:此树形选择器组件是基于elment-ui框架的el-select和el-tree组件的基础上改造的,其解决了原el-select组件的选项列表不能是树形的问题,集合了前两个组件的属性和方法封装成了一个组件,引入即可使用。其实现了树形列表、默认展开、默认选中、清空选值等功能,基本上可以满足大部分选择器的使用需求。

主要代码

组合el-select和el-tree组件:

<template>
 <el-select :value="valueTitle" :clearable="clearable" @clear="clearHandle">
  <el-option :value="valueTitle" :label="valueTitle">
   <el-tree id="tree-option"
    ref="selectTree"
    :accordion="accordion"
    :data="options"
    :props="props"
    :node-key="props.value"  
    :default-expanded-keys="defaultExpandedKey"
    @node-click="handleNodeClick">
   </el-tree>
  </el-option>
 </el-select>
</template>

封装组件:

<script>
export default {
 name: "el-tree-select",
 props:{
  /* 配置项 */
  props:{
   type: Object,
   default:()=>{
    return {
     value:'id',       // ID字段名
     label: 'title',     // 显示名称
     children: 'children'  // 子级字段名
    }
   }
  },
  /* 选项列表数据(树形结构的对象数组) */
  options:{
   type: Array,    
   default: ()=>{ return [] }
  },
  /* 初始值 */
  value:{
   type: Number,
   default: ()=>{ return null }
  },
  /* 可清空选项 */
  clearable:{
   type:Boolean,
   default:()=>{ return true }
  },
  /* 自动收起 */
  accordion:{
   type:Boolean,
   default:()=>{ return false }
  },
 },
 data() {
  return {
   valueId:this.value,  // 初始值
   valueTitle:'',
   defaultExpandedKey:[]  
  }
 },
 mounted(){
  this.initHandle()
 },
 methods: {
  // 初始化值
  initHandle(){
   if(this.valueId){
    this.valueTitle = this.$refs.selectTree.getNode(this.valueId).data[this.props.label]   // 初始化显示
    this.$refs.selectTree.setCurrentKey(this.valueId)    // 设置默认选中
    this.defaultExpandedKey = [this.valueId]   // 设置默认展开
   } 
   this.$nextTick(()=>{
    let scrollWrap = document.querySelectorAll('.el-scrollbar .el-select-dropdown__wrap')[0]
    let scrollBar = document.querySelectorAll('.el-scrollbar .el-scrollbar__bar')
    scrollWrap.style.cssText = 'margin: 0px; max-height: none; overflow: hidden;'
    scrollBar.forEach(ele => ele.style.width = 0)
   })
 
  },
  // 切换选项
  handleNodeClick(node){
   this.valueTitle = node[this.props.label]
   this.valueId = node[this.props.value]
   this.$emit('getValue',this.valueId)
   this.defaultExpandedKey = []
  },
  // 清除选中
  clearHandle(){
   this.valueTitle = ''
   this.valueId = null
   this.defaultExpandedKey = []
   this.clearSelected()
   this.$emit('getValue',null)
  },
  /* 清空选中样式 */
  clearSelected(){
   let allNode = document.querySelectorAll('#tree-option .el-tree-node')
   allNode.forEach((element)=>element.classList.remove('is-current'))
  }
 },
 watch: {
  value(){
   this.valueId = this.value
   this.initHandle()
  }
 },
};
</script>

css样式:

<style scoped>
 .el-scrollbar .el-scrollbar__view .el-select-dropdown__item{
  height: auto;
  max-height: 274px;
  padding: 0;
  overflow: hidden;
  overflow-y: auto;
 }
 .el-select-dropdown__item.selected{
  font-weight: normal;
 }
 ul li >>>.el-tree .el-tree-node__content{
  height:auto;
  padding: 0 20px;
 }
 .el-tree-node__label{
  font-weight: normal;
 }
 .el-tree >>>.is-current .el-tree-node__label{
  color: #409EFF;
  font-weight: 700;
 }
 .el-tree >>>.is-current .el-tree-node__children .el-tree-node__label{
  color:#606266;
  font-weight: normal;
 }
</style>

到此这篇关于基于Element的组件改造的树形选择器(树形下拉框)的文章就介绍到这了,更多相关Element 树形选择器内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
基于Web标准的UI组件 — 树状菜单(2)
Sep 18 Javascript
js中top的作用深入剖析
Mar 04 Javascript
jquery的clone方法应用于textarea和select的bug修复
Jun 26 Javascript
node.js中的http.response.getHeader方法使用说明
Dec 14 Javascript
jquery调取json数据实现省市级联的方法
Jan 29 Javascript
js添加事件的通用方法推荐
May 15 Javascript
快速获取/设置iframe内对象元素的几种js实现方法
May 20 Javascript
AngularJS实现DOM元素的显示与隐藏功能
Nov 22 Javascript
js实现密码强度检验
Jan 15 Javascript
如何将 jQuery 从你的 Bootstrap 项目中移除(取而代之使用Vue.js)
Jul 17 jQuery
详解element-ui日期时间选择器的日期格式化问题
Apr 08 Javascript
JS实现炫酷轮播图
Nov 15 Javascript
js与jquery获取input输入框中的值实例讲解
Feb 27 #jQuery
javascript将扁平的数据转为树形结构的高效率算法
Feb 27 #Javascript
js实现无限层级树形数据结构(创新算法)
Feb 27 #Javascript
js实现树形数据转成扁平数据的方法示例
Feb 27 #Javascript
vue学习笔记之给组件绑定原生事件操作示例
Feb 27 #Javascript
ElementUI Tree 树形控件的使用并给节点添加图标
Feb 27 #Javascript
ElementUI中el-tree节点的操作的实现
Feb 27 #Javascript
You might like
php学习笔记之基础知识
2014/11/08 PHP
ThinkPHP中RBAC类的四种用法分析
2014/11/24 PHP
php将从数据库中获得的数据转换成json格式并输出的方法
2018/08/21 PHP
offsetParent 算法分析
2010/04/05 Javascript
一个背景云变换js特效 鼠标移动背景云变化
2012/12/28 Javascript
JS中如何设置readOnly的值
2013/12/25 Javascript
JavaScript使用HTML5的window.postMessage实现跨域通信例子
2014/04/11 Javascript
jQuery实现tag便签去重效果的方法
2015/01/20 Javascript
轻松理解JavaScript闭包
2017/03/14 Javascript
基于对象合并功能的实现示例
2017/10/10 Javascript
发布Angular应用至生产环境的方法
2018/12/10 Javascript
JavaScript 禁止用户保存图片的实现代码
2020/04/28 Javascript
微信小程序学习之自定义滚动弹窗
2020/12/20 Javascript
[19:14]DOTA2 HEROS教学视频教你分分钟做大人-维萨吉
2014/06/24 DOTA
Python抓取Discuz!用户名脚本代码
2013/12/30 Python
python搜索指定目录的方法
2015/04/29 Python
python中装饰器级连的使用方法示例
2017/09/29 Python
浅谈python在提示符下使用open打开文件失败的原因及解决方法
2018/11/30 Python
python代码 输入数字使其反向输出的方法
2018/12/22 Python
python 使用pandas计算累积求和的方法
2019/02/08 Python
使用turtle绘制五角星、分形树
2019/10/06 Python
Pytorch Tensor基本数学运算详解
2019/12/30 Python
Tensorflow 多线程与多进程数据加载实例
2020/02/05 Python
Python 串口通信的实现
2020/09/29 Python
纯CSS实现设置半个字符的样式
2014/07/03 HTML / CSS
在IE6系列等老式浏览器中使用HTML5的新标签实现方案
2012/12/25 HTML / CSS
解决canvas转base64/jpeg时透明区域变成黑色背景的方法
2016/10/23 HTML / CSS
意大利在线药房:Farmacia Loreto Gallo
2019/08/09 全球购物
一些PHP的面试题
2015/05/06 面试题
NET程序员上机面试题
2015/05/23 面试题
车间主任岗位职责
2014/03/16 职场文书
团队激励口号
2014/06/06 职场文书
个人四风问题对照检查材料
2014/09/26 职场文书
婚前协议书范本
2014/10/27 职场文书
2015年母亲节寄语
2015/03/23 职场文书
2015年会计人员工作总结
2015/05/22 职场文书