这篇文章主要讲解了“Vue动态构建混合数据Treeselect选择树及巨树问题如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue动态构建混合数据Treeselect选择树及巨树问题如何解决”吧!
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); } }
由于后面要用懒加载,在引用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: [],
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动态构建混合数据Treeselect选择树及巨树问题如何解决”的内容了,经过本文的学习后,相信大家对Vue动态构建混合数据Treeselect选择树及巨树问题如何解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。