1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > vue+ElementUI实现下拉分级菜单:el-select嵌套el-tree树形控件实现下拉树效果(附带

vue+ElementUI实现下拉分级菜单:el-select嵌套el-tree树形控件实现下拉树效果(附带

时间:2019-10-30 20:53:24

相关推荐

vue+ElementUI实现下拉分级菜单:el-select嵌套el-tree树形控件实现下拉树效果(附带

先上完工效果图:

点击select框:

点击选项后:

输入框搜索选项功能:

直接上代码,说明写在注释里了,粘贴后注意要把部分注释删除再使用噢~

<template><div class="about">// select框绑定的值是selectVal,也就是treeData里的value<el-selectv-model="selectVal"placeholder="请选择..."size="mini"clearableref="select"style="width: 300px">// 设置一个input框用作模糊搜索选项功能<el-inputclass="input"placeholder="此处键入'关键词'搜索查询"prefix-icon="el-icon-search"v-model="treeFilter"size="mini"clearable></el-input>// 设置一个隐藏的下拉选项,选项显示的是汉字label,值是value// 如果不设置一个下拉选项,下面的树形组件将无法正常使用<el-option hidden key="id" :value="selectVal" :label="selectName"></el-option>// 设置树形控件<el-tree:data="treeData":props="defaultProps"@node-click="handleNodeClick":expand-on-click-node="false":check-on-click-node="true"ref="tree"node-key="id":default-expand-all="true":filter-node-method="filterNode">// @node-click:树形控件选项点击事件// :expand-on-click-node:使树形控件只有点箭头图标的时候才会展开或者收缩节点,为false则点文字直接选中该项// :check-on-click-node:是否在点击节点的时候选中节点,当选项为复选框时有用,这个属性可以删除// :default-expand-all:默认展开所有节点// :filter-node-method:实现搜索功能的筛选方法<span slot-scope="{ data }"> //选项用插槽来显示,匹配搜索功能,并方便增加tag标签需求<span>{{ data.label }}</span><el-tagsize="mini"style="margin: 0 10px"v-show="filterorgType(data.tag)">{{ filterorgType(data.tag) }}</el-tag></span></el-tree></el-select></div></template><script>export default {name: "el-select-tree",data() {return {selectVal: "", // select框的绑定值selectName: "", // select框显示的nametreeFilter: "", // 搜索框绑定值,用作过滤// 树形控件数据treeData: [{value: "1",label: "一级 1菈妮",tag: "wife",children: [{value: "1-1",label: "二级 1-1",children: [{value: "1-1-1",label: "三级 1-1-1",},],},],},{label: "一级 2",value: "2",children: [{value: "2-1",label: "二级 2-1",children: [{value: "2-1-1",label: "三级 2-1-1",},],},{value: "2-2",label: "二级 2-2",children: [{value: "2-2-1",label: "三级 2-2-1鸡腿",tag: "princess",},],},],},{value: "3",label: "一级 3",children: [{value: "3-1",label: "二级 3-1",children: [{value: "3-1-1",label: "三级 3-1-1",},],},{value: "3-2",label: "二级 3-2艾尔登法环",tag: "yyds",children: [{value: "3-2-1",label: "三级 3-2-1",},],},],},],defaultProps: {children: "children",label: "name",},// 标签数组tagList: [{value: "wife", label: "老婆" },{value: "princess", label: "小公主" },{value: "yyds", label: "天下第一" },],};},watch: {// 搜索过滤,监听input搜索框绑定的treeFiltertreeFilter(val) {this.$refs.tree.filter(val);// 当搜索框键入值改变时,将该值作为入参执行树形控件的过滤事件filterNode},},methods: {// 结构树点击事件handleNodeClick(data) {this.selectVal = data.value; // select绑定值为点击的选项的valuethis.selectName = data.label; // input中显示值为labelthis.treeFilter = ""; // 点击后搜索框清空this.$refs.select.blur(); // 点击后关闭下拉框,因为点击树形控件后select不会自动折叠},// 模糊查询(搜索过滤),实质为筛选出树形控件中符合输入条件的选项,过滤掉其他选项filterNode(value, data) {if (!value) return true;let filterRes = data.label.indexOf(value) !== -1;return filterRes;},// 选项卡标签(可忽略,增值迭代需求)filterorgType(val) {let arr = this.tagList.filter((item) => {return item.value == val;});return arr.length ? arr[0].label : "";},},mounted() {},};</script><style scoped>.input {width: 260px;margin: 10px;}</style>

等有空了再更新一下复选多选功能吧

若有帮到您请给我点赞三连当作鼓励~

THX~

39感谢日快乐~

vue+ElementUI实现下拉分级菜单:el-select嵌套el-tree树形控件实现下拉树效果(附带模糊查询搜索功能)

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。