良许Linux教程网 干货合集 Vue动态构建混合数据Treeselect选择树及巨树问题的解决方案

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

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

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

image-20220810221258507

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

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,所以不能选择,否则数据会乱。
"景区名称" prop="scenicId">
 "form.scenicId"
   :options="regionOptions"
   noChildrenText="更新中..."  
   :load-options="loadOptions"
   placeholder="请选择景区"
   :disable-branch-nodes="true">
 

四、构建初始的省级目录

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

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选择树及巨树问题的解决方法Vue动态构建混合数据Treeselect选择树及巨树问题的解决方法
Vue动态构建混合数据Treeselect选择树及巨树问题的解决方法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选择树及巨树问题的解决方法Vue动态构建混合数据Treeselect选择树及巨树问题的解决方法
Vue动态构建混合数据Treeselect选择树及巨树问题的解决方法Vue动态构建混合数据Treeselect选择树及巨树问题的解决方法

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

以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !

137e00002230ad9f26e78-265x300
本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部