阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Vue动态构建混合数据Treeselect选择树及巨树问题的解决方法

342次阅读
没有评论

共计 3259 个字符,预计需要花费 9 分钟才能阅读完成。

导读 今天在项目中需要通过行政区域选择,然后选择该行政区域下面的景区,也就是要构建行政区划、景区两表数据表的树。

全国的行政区域到县已经 3500 多了,再加上景区会有几万个点,这棵选择树不论是在后台还是在前台构建都比较大,会影响系统性能,需要前后端结合,动态构建,使用时用懒加载,提升系统性能。

一、后台构建两个表的数据选择查询功能

1、行政区域需要按省、市、县的 adcode 和级别查询,以便于动态构建。

两个参数,adcode 后台查询时会将后面的 0 去掉匹配,级别如果 0 或空,查询匹配下所有的,为数字只查本级。

这里有两个参数,用 @requestParam 传递的,注意要用 post,前端 VUE 使用 get 传递时会报错。

@PostMapping("/listjson")
    @ApiOperation("根据查询条件获取区划清单")
    public AjaxResult listJson(@RequestParam(name="adcode", required = true) String adcode, @RequestParam(name="level",required = true) String level)
    {System.out.println(adcode);
        List>  regionJson = iMapRegionService.selectRegionJson(adcode,level);
        return AjaxResult.success(regionJson);
    }
}

2、查询行政区域下的景区,根据 adcode 查询,一个参数,参数放在路径中传递的。

@GetMapping("/listByCode/{adcode}")
    @ApiOperation("根据查询条件获取景区清单")
    public AjaxResult listByCode(@PathVariable String adcode)
    {List> scenicList = iMapScenicService.selectScenicByCode(adcode);
        return AjaxResult.success(scenicList);
    }
}
二、在 VUE 中引入 Treeselect

由于后面要用懒加载,在引用 Treeselect 给件同时,还要引入 LOAD_CHILDREN_OPTIONS,Treeselect 要加到 components 中。

import {LOAD_CHILDREN_OPTIONS, Treeselect} from '@riophae/vue-treeselect'
  import '@riophae/vue-treeselect/dist/vue-treeselect.css'
  export default {components: { Treeselect},
    data() {
      return {
        // 地点列表
        regionOptions: [],
三、使用 Treeselect 组件
noChildrenText=“更新中…”, // 由于缺省会将没有加载下级节点的 children 设置为 null,系统缺省会显示 No sub-options,点击节点是,显示更新中更好,更新完成显示子节点。:load-options=“loadOptions”// 增加此选项,在后方扩展子节点是会调用此方法,第一是点击左边的三解形,第二下面将非叶子节点设置为不能选择,点击节点也会自动扩展。:disable-branch-nodes=“true”> // 将树枝节点设置为不能选择,树枝节点是行政区域,也不我们需要的景区 ID,所以不能选择,否则数据会乱。
四、构建初始的省级目录

组件打开初始化时,构建一级选择树

created() {this.getList()
      this.getTreeselect()},
    methods: {
      /** 生成查询行政区划下拉树结构第一级 */
      getTreeselect() {let formData = new FormData()    // 构建需要查询的参数,先选择省节点
        formData.append('adcode', '000000')  
        formData.append('level', '1')
        listJson(formData).then(response => {  //listJson 对应是询后台行政区域的接口函数
          let data = response.data
          data.forEach(element => {element['id'] = element.code // 后台传递过来的是 code 和 name,需要换为 treeselect 所需要的 id 和 label
            element['label'] = element.name
            element['level'] = '1'    // 设置为 1 级,后续判断需要
            element['children'] = null  // 要设置为空,才能触发:load-options="loadOptions" 动用
          })
          this.regionOptions = data
        })
      },

Vue 动态构建混合数据 Treeselect 选择树及巨树问题的解决方法

五、构建动态生成的二、三、四级目录
// 动态添加树的子节点
     loadOptions({action, parentNode, callback}) {if (action === LOAD_CHILDREN_OPTIONS) {let formData = new FormData()
         formData.append('adcode', parentNode.id)
         switch (parentNode.level) {  // 判断选择级别
           case '1' :
             /** 生成查询行政区划下拉树结构第二级 */
             formData.append('level', '2') 
             listJson(formData).then(res => {    // 选择市,构建 2 级
               if (res.code === 200) {  // 后台返回是用 code 表示返回状态代码,与后台匹配
                 let data = res.data
                 data.forEach(element => {element['id'] = element.code 
                   element['label'] = element.name
                   element['level'] = '2'
                   element['children'] = null
                 })
                 parentNode.children = data  // 增加子节点
               }
             })
             callback()
             break
           case '2' :
             /** 生成查询行政区划下拉树结构第三级 */
             formData.append('level', '3')
             listJson(formData).then(res => {if (res.code === 200) {
                 let data = res.data
                 data.forEach(element => {element['id'] = element.code 
                   element['label'] = element.name
                   element['level'] = '3'
                   element['children'] = null
                 })
                 parentNode.children = data
               }
             })
             callback()
             break
           case '3' :
             /** 生成查询行政区下的景区清单 */
             listByCode(parentNode.id).then(res => {    // 第四级是景区,使用的是景区表,根据 adcode 查询
               if (res.code === 200) {
                 let data = res.data
                 console.log(data)
                 data.forEach(element => {
                   // 为景区增加一个图标,以示区别
                   element['label'] = element['label'] + ''   // 使用 emoji 文件,标识这是景区,treeselect 没有 icon 图标
                   element['level'] = '4'
                    })
                 parentNode.children = data
               }
             })
             callback()
             break
         }
       }
     }
六、最后效果

Vue 动态构建混合数据 Treeselect 选择树及巨树问题的解决方法

这个方法动态实现 Treeselect 构建,可以解决巨树构建问题。

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-25发表,共计3259字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7803278
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

还在忍受动辄数百兆的“全家桶”监控软件?后台偷占资源、界面杂乱冗余,想查个 CPU 温度都要层层点选? 今天给...
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流! 大家好,我是星哥,今天才思枯竭,不写技术文章了!来吐槽一下 CSDN。...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的Nano Banana Pro?附赠邪修的用法

如何免费使用强大的 Nano Banana Pro?附赠邪修的用法 前言 大家好,我是星哥,今天来介绍谷歌的 ...
浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍 前言 在 AI 自动化快速发展的当下,浏览器早已不再只是...
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛 NAS-12:开源笔记的进化之路,效率玩家的新选择 前言 如何高效管理知识与笔记,已经成为技术...
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...