vue2+elementUI的el-tree的选中、高亮、定位功能的实现
更新时间:2022年09月19日 09:42:08 作者:懒啦
这篇文章主要介绍了vue2+elementUI的el-tree的选中、高亮、定位功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
在使用无选择框的el-tree时遇到的坑以及如何使用el-tree
最后附全部代码
ref="tree" ----> 必须写 accordion ----> 是否每次只打开一个同级树节点展开 看个人选择 default-expand-all ----> 默认打开全部节点 :data="leftData" ----> 必写 展示数据 @node-click="handleNodeClick" ----> 节点被点击时的回调 node-key="listId" ----> 设置选中的数据 必须写 注意不要写 ':' 我当时就是写了 找错找了得有好几个小时 哭死 :current-node-key="currentNodeKey" ----> 设置选中必须写 :highlight-current="true" ----> 设置高亮 必须写 :props="defaultProps" ----> 可以配置节点标签的属性值
props的配置
HTML部分
<el-tree ref="tree" default-expand-all :data="data" @node-click="handleNodeClick" node-key="id" :current-node-key="currentNodeKey" :highlight-current="true" :props="defaultProps" > <span class="custom-tree-node" slot-scope="{ node, data }"> <span :id="data.id">{{ node.label }}</span> </span> </el-tree> <el-button @click="nodeClick1" type="primary">点击后选中id为006的</el-button>
JS部分
<script> export default { data() { return { data: [ { id: 1, name: "一级 1", children: [ { id: 4, name: "二级 1-1", children: [ { id: 9, name: "三级 1-1-1", }, { id: 10, name: "三级 1-1-2", }, ], }, ], }, { id: 2, name: "一级 2", children: [ { id: "005", name: "二级 2-1", }, { id: "006", name: "二级 2-2", }, ], }, { id: 3, name: "一级 3", children: [ { id: 7, name: "二级 3-1", }, { id: 8, name: "二级 3-2", children: [ { id: 11, name: "三级 3-2-1", }, { id: 12, name: "三级 3-2-2", }, { id: 13, name: "三级 3-2-3", }, ], }, ], }, ], defaultProps: { children: "children", label: "name", }, currentNodeKey: "", }; }, watch: { currentNodeKey(newVal) { if (newVal.toString()) { this.$refs["tree"].setCurrentKey(newVal); } else { this.$refs["tree"].setCurrentKey(null); } }, }, methods: { // 点击节点 handleNodeClick(data,node){ this.currentNodeKey = data.id; // 判断点击的层级进行操作 if(node.level == 1){ console.log('第一层data1',data); console.log('第一层node1',node); }else if(node.level == 2){ console.log('第二层data2',data); console.log('第二层node2',node); }else if(node.level == 3){ console.log('第三层data3',data); console.log('第三层node3',node); } }, nodeClick1(){ // 点击选中006号 this.$refs.tree.setCurrentKey('006'); }, // 如果数据过多可以调用这个方法并传入要显示的id //滚动到选中定位的位置 selectedRegion(id) { console.log("滚动到选中定位的位置"); // 通过Id获取到对应的dom元素 const node = document.getElementById(id); setTimeout(() => { if (node) { this.$nextTick(() => { // 通过scrollIntoView方法将对应的dom元素定位到可见区域 【block: 'center'】这个属性是在垂直方向居中显示 node.scrollIntoView({ block: "center" }); }); } }, 100); }, }, }; </script>
修改样式
<style scoped> /* 点击时的样式 */ .el-tree ::v-deep.el-tree-node:focus > .el-tree-node__content { background-color: #edf3fc !important; border-radius: 8px; } /* tree 的高度和宽度重新定义 */ ::v-deep.el-tree .el-tree-node > .el-tree-node__content { width: 300px; height: 40px; } /* 鼠标hover改变背景颜色 */ .el-tree ::v-deep.el-tree-node > .el-tree-node__content:hover { background-color: #edf3fc !important; border-radius: 8px; } /* 颜色高亮 */ ::v-deep.el-tree--highlight-current .el-tree-node.is-current > .el-tree-node__content { background-color: #edf3fc !important; border-radius: 8px; } </style>
附上全部代码
<style scoped> /* 点击时的样式 */ .el-tree ::v-deep.el-tree-node:focus > .el-tree-node__content { background-color: #edf3fc !important; border-radius: 8px; } /* tree 的高度和宽度重新定义 */ ::v-deep.el-tree .el-tree-node > .el-tree-node__content { width: 300px; height: 40px; } /* 鼠标hover改变背景颜色 */ .el-tree ::v-deep.el-tree-node > .el-tree-node__content:hover { background-color: #edf3fc !important; border-radius: 8px; } /* 颜色高亮 */ ::v-deep.el-tree--highlight-current .el-tree-node.is-current > .el-tree-node__content { background-color: #edf3fc !important; border-radius: 8px; } </style>
到此这篇关于vue2+elementUI的el-tree的选中、高亮、定位的文章就介绍到这了,更多相关vue2 elementUI选中、高亮、定位内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue.js中使用微信扫一扫解决invalid signature问题(完美解决)
这篇文章主要介绍了vue.js中使用微信扫一扫解决invalid signature问题(推荐),本文通过实例代码给出解决方法,代码简单易懂非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2020-04-04Vue API中setup ref reactive函数使用教程
setup是用来写组合式api,内部的数据和方法需要通过return之后,模板才能使用。在之前vue2中,data返回的数据,可以直接进行双向绑定使用,如果我们把setup中数据类型直接双向绑定,发现变量并不能实时响应。接下来就详细看看它们的使用2022-12-12使用vue ant design分页以及表格分页改为中文问题
这篇文章主要介绍了使用vue ant design分页以及表格分页改为中文问题,具有很好的参考价值,希望对大家有所帮助。2023-04-04
最新评论