一款基于vue2.x,同时支持少量数据或大量数据、多种功能和虚拟滚动(支持固定节点高度和动态节点高度)的树组件。
基于element-ui(License:MIT)中抽取的tree样式和功能,结合vue-virtual-scroller(License:MIT)所做的树组件。
- 大数据量支持虚拟滚动(支持固定节点高度和动态节点高度)
- 基本树形数据的展示
- 支持checkbox选择
- 支持懒加载
- 默认展开和默认选中
- 禁用节点
- 通过多种方式选中节点和获取选中的节点信息
- 支持自定义节点内容
- 支持节点过滤
- 非虚拟滚动下,支持手风琴模式
- 非懒加载时,支持节点拖拽
- 支持虚拟滚动
- 不仅支持大数据量的树形数据展示,还支持数据的操作和更改
- 不仅支持固定高度的子item的虚拟滚动,还支持子item动态高度的虚拟滚动
npm install @ba1q1/vue-easy-tree
或
yarn add @ba1q1/vue-easy-tree
在 main.js
文件中引入:
import Vue from "vue";
import VueEasyTree from "@ba1q1/vue-easy-tree";
// 样式文件,可以根据需要自定义样式或主题
import "@ba1q1/vue-easy-tree/src/assets/index.scss"
Vue.use(VueEasyTree)
在组件中引入:
import VueEasyTree from "@ba1q1/vue-easy-tree";
// 样式文件,可以根据需要自定义样式或主题
import "@ba1q1/vue-easy-tree/src/assets/index.scss"
export default {
components: {
VueEasyTree
}
}
node-key
。
<template>
<div class="ve-tree" style="height:calc(100vh - 20px)">
<!-- 不使用虚拟滚动时只需去掉height参数即可 -->
<vue-easy-tree
ref="veTree"
node-key="id"
height="calc(100vh - 20px)"
:data="treeData"
:props="props"
></vue-easy-tree>
</div>
</template>
<script>
export default {
data() {
return {
props: {
label: "name",
children: "children"
},
treeData: []
};
},
created() {
const data = [],
root = 8,
children = 3,
base = 1000;
for (let i = 0; i < root; i++) {
data.push({
id: `${i}`,
name: `test-${i}`,
children: []
});
for (let j = 0; j < children; j++) {
data[i].children.push({
id: `${i}-${j}`,
name: `test-${i}-${j}`,
children: []
});
for (let k = 0; k < base; k++) {
data[i].children[j].children.push({
id: `${i}-${j}-${k}`,
name: `test-${i}-${j}-${k}`
});
}
}
}
this.treeData = data;
}
};
</script>
通过新建一个样式文件,如:ve-tree-var.scss
,写入以下内容:
/* 改变主题色变量 */
$--color-primary: #ea5404;
/* 改变 icon 字体路径变量,必需 */
$--font-path: "~@ba1q1/vue-easy-tree/src/assets/fonts";
@import "@ba1q1/vue-easy-tree/src/assets/index.scss";
然后在 main.js
中直接引入以上样式文件即可:
import Vue from 'vue'
import VueEasyTree from "@ba1q1/vue-easy-tree";
import "./css/ve-tree-var.scss"
Vue.use(VueEasyTree)
来自element-ui 官方文档
需要使用虚拟滚动时,增加 height
属性即可,如:
<vue-easy-tree :data="data" height="calc(100vh - 20px)" :props="defaultProps" @node-click="handleNodeClick"></vue-easy-tree>
<!-- 默认开启固定高度模式,子item动态高度模式需要手动开启,如下:isDynamic为true开启,配合minItemSize设置第一次渲染时的子item最小高度 -->
<vue-easy-tree :data="data" height="calc(100vh - 20px)" :props="defaultProps" @node-click="handleNodeClick" :minItemSize="50" isDynamic></vue-easy-tree>