通过el-tree 懒加载树,创建国家地区四级树

全国四级行政地区树数据库sql下载路径:【免费】全国四级地区(省市县)数据表sql资源-CSDN文库https://download.csdn.net/download/weixin_51722520/88469807?spm=1001.2014.3001.5503

我在后台获取地区信息添加了限制,只获取parentid为当前的地区没所以没有显示全国数据

前端使用饿了么的组件,添加lazy做懒加载,不需要将数据递归组装成树结构返回,每次点击时,向后端发送请求,请求当前父级下的子数据 。

html 复制代码
<el-card style="height: 95%">
     <div style="  height: 520px; display: block;overflow-y: scroll;">
      <el-tree lazy :props="defaultProps" :load="loadNode" @node-click="handleNodeClick"></el-tree>
     </div>
</el-card>

绑定数据结构,label为展示的数据,isLeaf为是否是子节点,后端传值时,将isLeaf设置为true即可。

html 复制代码
   defaultProps: {
                    label: "name",
                    isLeaf: "isLeaf",
                },

loadNode会在页面被点击时自动调用,resolve回调方法会将查询到的数据,放入到树中,不需要将数据绑定。

这里将数据做了判断,为空时给他赋值为141100000000,不为空则将node节点id给到父级id

loadNode就是树的点击事件触发的方法

loadNode回调resolve只接受List类型的数据

html 复制代码
    //懒加载时查询叶子节点
            loadNode(node, resolve) {
                let params = node.data ? ('parent.id=' + node.data.id) : ('id=141100000000')
                this.get(ctx + '/basicinfo/region/getLeftNode?' + params).then((res) => {
                    resolve(res)
                })
            },

将点击时的node节点调用(可以不用写,与树没有太大联系,只是我业务中会用这个方法)

html 复制代码
    handleNodeClick(node, e) {
                 console.log("树被点击时调用事件")
            },
相关推荐
小高0073 分钟前
🔥3 kB 换 120 ms 阻塞? Axios 还是 fetch?
前端·javascript·面试
千寻girling5 分钟前
面试官 : “ Vue 选项式api 和 组合式api 什么区别? “
前端·vue.js·面试
华仔啊1 小时前
Vue 组件通信的 8 种最佳实践,你知道几种?
前端·vue.js
POLITE31 小时前
Leetcode 234.回文链表 JavaScript (Day 9)
javascript·leetcode·链表
Ahtacca1 小时前
Linux环境下前后端分离项目(Spring Boot + Vue)手动部署全流程指南
linux·运维·服务器·vue.js·spring boot·笔记
老前端的功夫2 小时前
TypeScript 全局类型声明:declare关键字的深度解析与实战
linux·前端·javascript·ubuntu·typescript·前端框架
EndingCoder2 小时前
TypeScript 入门:理解其本质与价值
前端·javascript·ubuntu·typescript·node.js
2501_946244783 小时前
Flutter & OpenHarmony OA系统弹窗对话框组件开发指南
javascript·flutter·microsoft
烟袅3 小时前
从定时器管理出发,彻底搞懂防抖与节流的实现逻辑
前端·javascript
计算机毕设VX:Fegn08953 小时前
计算机毕业设计|基于springboot + vue小区人脸识别门禁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计