基于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 相关文章推荐
IE6下拉框图层问题探讨及解决
Jan 03 Javascript
jQuery不使用插件及swf实现无刷新文件上传
Dec 08 Javascript
纯JS实现旋转图片3D展示效果
Apr 12 Javascript
解决Vue不能检测数组或对象变动的问题
Feb 24 Javascript
一个Vue视频媒体多段裁剪组件的实现示例
Aug 09 Javascript
Mint-UI时间组件起始时间问题及时间插件使用
Aug 20 Javascript
jQuery实现动态生成年月日级联下拉列表示例
May 11 jQuery
Element-UI中关于table表格的那些骚操作(小结)
Aug 15 Javascript
微信小程序 简易计算器实现代码实例
Sep 02 Javascript
layui之数据表格--与后台交互获取数据的方法
Sep 29 Javascript
微信小程序日历插件代码实例
Dec 04 Javascript
ant design vue导航菜单与路由配置操作
Oct 28 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下使用iconv需要注意的问题
2010/11/20 PHP
jquerymobile checkbox及时刷新才能获取其准确值
2012/04/14 Javascript
JQuery设置和去除disabled属性的5种方法总结
2013/05/16 Javascript
Javascript中常见的校验如域名、手机、邮箱等等
2014/01/02 Javascript
JS计算网页停留时间代码
2014/04/28 Javascript
jQuery对象初始化的传参方式
2015/02/26 Javascript
JQuery菜单效果的两个实例讲解(3)
2015/09/17 Javascript
JavaScript设计模式初探
2016/01/07 Javascript
ArtEditor富文本编辑器增加表单提交功能
2016/04/18 Javascript
深入理解vue Render函数
2017/07/19 Javascript
node前端模板引擎Jade之标签的基本写法
2018/05/11 Javascript
JavaScript 扩展运算符用法实例小结【基于ES6】
2019/06/17 Javascript
浅谈javascript如何获取文件后缀名
2020/08/07 Javascript
如何使用RoughViz可视化Vue.js中的草绘图表
2021/01/30 Vue.js
Python中endswith()函数的基本使用
2015/04/07 Python
总结Python编程中三条常用的技巧
2015/05/11 Python
python清除指定目录内所有文件中script的方法
2015/06/30 Python
Python中不同进制的语法及转换方法分析
2016/07/27 Python
Python自定义装饰器原理与用法实例分析
2018/07/16 Python
Python使用到第三方库PyMuPDF图片与pdf相互转换
2019/05/03 Python
Python PyQt5 Pycharm 环境搭建及配置详解(图文教程)
2019/07/16 Python
pycharm编写spark程序,导入pyspark包的3中实现方法
2019/08/02 Python
python库matplotlib绘制坐标图
2019/10/18 Python
Tensorflow实现多GPU并行方式
2020/02/03 Python
在python中使用pymysql往mysql数据库中插入(insert)数据实例
2020/03/02 Python
Python实现猜年龄游戏代码实例
2020/03/25 Python
Django REST Framework 分页(Pagination)详解
2020/11/30 Python
机电工程专业应届生求职信
2013/10/03 职场文书
大课间活动制度
2014/01/18 职场文书
会计岗位职责范本
2014/03/07 职场文书
环境科学专业教师求职信
2014/07/12 职场文书
专题民主生活会对照检查材料思想汇报
2014/09/29 职场文书
三方股份合作协议书
2014/10/13 职场文书
2015年财务部年度工作总结
2015/05/19 职场文书
拿破仑传读书笔记
2015/07/01 职场文书
学校教师培训工作总结
2015/10/14 职场文书