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

 更新时间:2022年07月26日 11:27:16   作者:海盐老伍  
这篇文章主要介绍了Vue动态构建混合数据Treeselect选择树及巨树问题的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

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

全国的行政区域到县已经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<Map<String, String>>  regionJson = iMapRegionService.selectRegionJson(adcode,level);
        return AjaxResult.success(regionJson);
    }
}

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

    @GetMapping("/listByCode/{adcode}")
    @ApiOperation("根据查询条件获取景区清单")
    public AjaxResult listByCode(@PathVariable String adcode)
    {
        List<Map<String, String>> 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,所以不能选择,否则数据会乱。
<el-form-item label="景区名称" prop="scenicId">
  <treeselect
    v-model="form.scenicId"
    :options="regionOptions"
    noChildrenText="更新中..."  
    :load-options="loadOptions"
    placeholder="请选择景区"
    :disable-branch-nodes="true">
  </treeselect>
</el-form-item>

四、构建初始的省级目录

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

 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
        })
      },

五、构建动态生成的二、三、四级目录

 //动态添加树的子节点
      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
          }
        }
      }

六、最后效果

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue实现动态查询规则生成组件

    Vue实现动态查询规则生成组件

    今天我们来给大家介绍下在Vue开发中我们经常会碰到的一种需求场景,本文主要介绍了Vue动态查询规则生成组件,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • elementUI中input回车触发页面刷新问题与解决方法

    elementUI中input回车触发页面刷新问题与解决方法

    这篇文章主要给大家介绍了关于elementUI中input回车触发页面刷新问题与解决方法,文中通过实例代码介绍的非常详细,对大家学习或者使用elementUI具有一定的参考学习价值,需要的朋友可以参考下
    2023-07-07
  • 使用@tap.stop阻止事件继续传播

    使用@tap.stop阻止事件继续传播

    这篇文章主要介绍了使用@tap.stop阻止事件继续传播,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Vue this.$router.push(参数)实现页面跳转操作

    Vue this.$router.push(参数)实现页面跳转操作

    这篇文章主要介绍了Vue this.$router.push(参数)实现页面跳转操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • vue中实现高德定位功能

    vue中实现高德定位功能

    这篇文章主要介绍了vue中实现高德定位功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • Vue实现下载文件而非浏览器直接打开的方法

    Vue实现下载文件而非浏览器直接打开的方法

    对于浏览器来说,文本、图片等可以直接打开的文件,不会进行自动下载,下面这篇文章主要给大家介绍了关于Vue实现下载文件而非浏览器直接打开的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • Vue+Openlayer实现图形的拖动和旋转变形效果

    Vue+Openlayer实现图形的拖动和旋转变形效果

    Openlayer具有自己的扩展插件ol-ext,可以用来实现图形的拖拽、旋转、缩放、拉伸、移动等操作,本文将主要介绍通过Openlayer实现图形的拖动和旋转,需要的同学可以学习一下
    2021-11-11
  • 详解vue路由

    详解vue路由

    这篇文章主要介绍了vue路由的相关资料,文中讲解非常细致,帮助大家更好的理解和学习vue路由知识,感兴趣的朋友可以了解下
    2020-08-08
  • Vue项目中最新用到的一些实用小技巧

    Vue项目中最新用到的一些实用小技巧

    这篇文章主要给大家介绍了关于Vue项目中最新用到的一些实用小技巧,文中通过示例代码介绍的非常详细,对大家学习或者使用vue具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • vue父组件向子组件传递多个数据的实例

    vue父组件向子组件传递多个数据的实例

    下面小编就为大家分享一篇vue父组件向子组件传递多个数据的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03

最新评论