vue里使用elementui的级联选择器el-cascader进行懒加载的怎么实现数据回显?

需要实现的懒加载回显效果

比如:后端返回数据 广东省/广州市/天河区440000000000/440100000000/440106000000,需要我们自动展开到天河区的下一级,效果如下

代码实现

我的实现思路就是拿到 440000000000/440100000000/440106000000 每一层级的数据,然后组成一个树。

这里接口 getAreaList 返回的数据格式如下:

js 复制代码
[
	{
		areaCode: "440106000000",
		areaLevel: "4",
		areaName: "天河区",
		areaSeq: "5",
		childNum: 21,
		parentAreaSeq: "xxx"
	}
]

组件试下如下:

html 复制代码
<template>
    <div class="cascader-lazy">
        <h2>需要回显的地区:广东省/广州市/天河区</h2>
        <h3>需要回显的地区对应的编码:440000000000/440100000000/440106000000</h3>
        <el-cascader ref="cascaderLazy" :options="dataList" :props="props" v-model="areaList" />
    </div>
</template>

<script>
import axios from "axios";

export default {
    name: "CascaderLazy",
    data() {
        return {
            areaList: [],
            dataList: [],
            props: {
                value: "areaCode",
                label: "areaName",
                lazy: true,
                lazyLoad: this.lazyLoad
            }
        };
    },
    mounted() {
        this.areaList = ["440000000000", "440100000000", "440106000000"];
        this.loadOptions(this.areaList);
    },
    methods: {
        // 获取数据
        getAreaList(parentAreaSeq) {
            return new Promise(async (resolve, reject) => {
                try {
                    const response = await axios.get("xxxx", {
                        params: {
                            parentAreaSeq: parentAreaSeq
                        }
                    });
                    resolve(
                        response.data.data.map((el) => {
                            el.leaf = el.childNum === 0;
                            return el;
                        })
                    );
                } catch (error) {
                    console.error(error);
                    reject();
                }
            });
        },
        // 遍历一级选择框,把二级选择框的数据放在一级的children属性上
        async loadOptions(areaList) {
            // 先初始调用一次
            let tempArr = [];
            let initRes = await this.getAreaList();
            tempArr.push(initRes);
            // 然后遍历 areaList 找到对应的 areaSeq 获取地区列表
            for (let i = 0; i < areaList.length; i++) {
                if (areaList.length > 0) {
                    let areaSeq = "";
                    areaSeq = tempArr[i].filter((el) => el.areaCode === areaList[i]).map((el) => el.areaSeq)[0];
                    let res = await this.getAreaList(areaSeq);
                    tempArr.push(res);
                }
            }
            // 先加一个最后层级的地区用于展示,最后在删掉
            if (tempArr[areaList.length][0]) {
                areaList.push(tempArr[areaList.length][0].areaCode);
            }
            // 从后面开始遍历组成一个树
            for (let len = tempArr.length - 1; len >= 0; len--) {
                if (len - 1 < 0) break;
                // 给当前areaCode添加children
                tempArr[len - 1].forEach((item) => {
                    if (item.areaCode === areaList[len - 1]) {
                        item.children = tempArr[len];
                    }
                });
            }
            this.dataList = tempArr[0];
            // 删掉最后选中的
            this.$nextTick(() => {
                areaList.pop();
                // 点击自动下拉出来
                this.$refs.cascaderLazy.$el.click();
            });
        },
        async lazyLoad(node, resolve) {
            let nodes = [];
            if (node.level !== 0 && node.data) {
                nodes = await this.getAreaList(node.data.areaSeq);
            }
            resolve(nodes);
        }
    }
};
</script>
相关推荐
NCDS程序员2 小时前
v-model: /v-model/ :(v-bind)三者核心区别
前端·javascript·vue.js
小杨同学呀呀呀呀2 小时前
Ant Design Vue <a-timeline>时间轴组件失效解决方案
前端·javascript·vue.js·typescript·anti-design-vue
Mr Xu_10 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠11 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
未来之窗软件服务12 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
phltxy13 小时前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
Byron070714 小时前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js
Byron070716 小时前
从 0 到 1 搭建 Vue 前端工程化体系:提效、提质、降本实战落地
前端·javascript·vue.js
zhengfei61116 小时前
【AI平台】- 基于大模型的知识库与知识图谱智能体开发平台
vue.js·语言模型·langchain·知识图谱·多分类
徐小夕@趣谈前端16 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6