基于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 相关文章推荐
javascript 面向对象思想 附源码
Jul 07 Javascript
jQuery的图片滑块焦点图插件整理推荐
Dec 07 Javascript
jQuery中[attribute=value]选择器用法实例
Dec 31 Javascript
JavaScript将字符串转换成字符编码列表的方法
Mar 19 Javascript
JS动态修改图片的URL(src)的方法
Apr 01 Javascript
常用原生js自定义函数总结
Nov 20 Javascript
React-Native实现ListView组件之上拉刷新实例(iOS和Android通用)
Jul 11 Javascript
JS实现的简单表单验证功能示例
Oct 13 Javascript
JS数组去重的6种方法完整实例
Dec 08 Javascript
使用node搭建自动发图文微博机器人的方法
Mar 22 Javascript
vue中父子组件传值,解决钩子函数mounted只运行一次的操作
Jul 27 Javascript
vue的hash值原理也是table切换实例代码
Dec 14 Vue.js
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 计算两个时间戳相隔的时间的函数(小时)
2009/12/18 PHP
php输出表格的实现代码(修正版)
2010/12/29 PHP
教大家制作简单的php日历
2015/11/17 PHP
PHP下载文件的函数实例代码
2016/05/18 PHP
js中scrollHeight,scrollWidth,scrollLeft,scrolltop等差别介绍
2012/05/16 Javascript
js的隐含参数(arguments,callee,caller)使用方法
2014/01/28 Javascript
QQ空间顶部折页撕开效果示例代码
2014/06/15 Javascript
Javascript中判断对象是否为空
2015/06/10 Javascript
超链接怎么正确调用javascript函数
2016/05/23 Javascript
AngularJS表格详解及示例代码
2016/08/17 Javascript
Javascript中indexOf()和lastIndexOf应用方法实例
2016/08/24 Javascript
jQuery动态添加与删除tr行实例代码
2016/10/18 Javascript
AngularJS 应用身份认证的技巧总结
2016/11/07 Javascript
深入解析js轮播插件核心代码的实现过程
2017/04/14 Javascript
vue2.0+koa2+mongodb实现注册登录
2018/04/10 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
2018/11/14 Javascript
js实现转动骰子模型
2019/10/24 Javascript
layui数据表格重载实现往后台传参
2019/11/15 Javascript
vue-cli4项目开启eslint保存时自动格式问题
2020/07/13 Javascript
解决vux 中popup 组件Mask 遮罩在最上层的问题
2020/11/03 Javascript
基于Django模板中的数字自增(详解)
2017/09/05 Python
Python创建对称矩阵的方法示例【基于numpy模块】
2017/10/12 Python
教你用Python写安卓游戏外挂
2018/01/11 Python
PyQt5每天必学之单行文本框
2018/04/19 Python
python matplotlib绘图,修改坐标轴刻度为文字的实例
2018/05/25 Python
python 递归深度优先搜索与广度优先搜索算法模拟实现
2018/10/22 Python
python找出列表中大于某个阈值的数据段示例
2019/11/24 Python
pycharm 关闭search everywhere的解决操作
2021/01/15 Python
英国DIY汽车维修配件网站:DIY Car Service Parts
2019/08/30 全球购物
数控技校生自我鉴定
2014/04/19 职场文书
文明城市创建标语
2014/06/16 职场文书
党委干部批评与自我批评发言稿
2014/09/28 职场文书
教师个人年度总结
2015/02/11 职场文书
小学生光盘行动倡议书
2015/04/28 职场文书
2015年行政助理工作总结
2015/04/30 职场文书
Python可变与不可变数据和深拷贝与浅拷贝
2022/04/06 Python