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

news2024/10/7 16:21:27

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

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

在这里插入图片描述

代码实现

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

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

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

组件试下如下:

<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>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1040913.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YOLOv5如何训练自己的数据集(生活垃圾数据集为例)

文章目录 前言1、数据标注说明2、定义自己模型文件3、训练模型参考文献 前言 本文主要介绍如何利用YOLOv5训练自己的数据集 1、数据标注说明 以生活垃圾数据集为例子 生活垃圾数据集&#xff08;YOLO版&#xff09;点击这里直接下载本文生活垃圾数据集 生活垃圾数据集组成&…

软件测试/测试开发丨利用人工智能ChatGPT自动生成PPT

点此获取更多相关资料 简介 PPT 已经渗透到我们的日常工作中&#xff0c;无论是工作汇报、商务报告、学术演讲、培训材料都常常要求编写一个正式的 PPT&#xff0c;协助完成一次汇报或一次演讲。PPT相比于传统文本的就是有布局、图片、动画效果等&#xff0c;可以给到观众更好…

VSCode 和 CLion

文章目录 一、VSCode1、文档2、插件3、智能编写4、VSCode 与 C&#xff08;1&#xff09;安装&#xff08;2&#xff09;调试&#xff08;a&#xff09;使用 CMake 进行跨平台编译与调试&#xff08;b&#xff09;launch.json&#xff08;c&#xff09;传参 &#xff08;3&…

mac有必要用清理软件吗

随着科技的不断进步&#xff0c;我们的计算机硬盘容量也在不断增长。即使是ARM架构的处理器&#xff0c;也可以通过高效的文件系统和技术来充分利用磁盘空间。然而&#xff0c;对于使用Mac OS系统的用户来说&#xff0c;仅仅使用一个盘来存储所有文件可能会导致一些残留文件的问…

深入了解 Docker 容器操作命令:掌握容器化管理的关键

Docker 已经成为现代应用程序开发和部署的行业标准。它借助容器化技术&#xff0c;提供了一种轻量、可移植和可扩展的方式来构建、发布和运行应用程序。然而&#xff0c;最近我在工作中发现&#xff0c;一些家人们对 Docker 容器的操作命令还不太熟悉。因此&#xff0c;本文旨在…

C++之std::function类模板定义函数对象应用总结(二百三十八)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

PWN基础:从源文件到可执行文件

目录 编译原理 GCC编译过程 Preprocess阶段 File命令 Compile阶段 Assemble阶段 Link阶段 高级语言编写的程序想在操作系统运行&#xff0c;需要被翻译为机器指令&#xff0c;在按照可执行目标文件格式打包并以二进制形式存储在文件中 编译原理 编译器作用&#xff1a;…

php实现分页功能跳转和ajax方式实现

实现效果 准备工作 创建数据表和导入测试数据 CREATE TABLE users ( id int(10) unsigned NOT NULL AUTO_INCREMENT, username varchar(30) DEFAULT NULL COMMENT 账号, email varchar(30) DEFAULT NULL COMMENT 密码, PRIMARY KEY (id) ) ENGINEMyISAM AUTO_INCREM…

Docker 容器编排

是什么 Docker-Compose是 Docker 官方的开源项目&#xff0c;负责实现对Docker容器集群的快速编排。 Compose 是 Docker 公司推出的一个工具软件&#xff0c;可以管理多个 Docker 容器组成一个应用。你需要定义一个 YAML 格式的配置文件docker-compose.yml&#xff0c;写好多个…

基于微信小程序的医院门诊体检预约管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言系统主要功能&#xff1a;具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计…

Xcode15下载iOS17一直中断解决办法

1、问题描述 目前的 xcode 15 安装时&#xff0c;跟以前有个差别&#xff1a;以往的 xcode 安装时自带了 ide、sdk 等工具包&#xff0c;安装后即可开始开发&#xff0c;而最新的包则被分开成了不同的包&#xff0c;这里以 ios 开发包为例&#xff1a;Xcode_15.xip 和 iOS_17_…

网络编程-UDP协议(发送数据和接收数据)

需要了解TCP协议的&#xff0c;可以看往期文章 https://blog.csdn.net/weixin_43860634/article/details/133274701 TCP/IP参考模型 通过此图&#xff0c;可以了解UDP所在哪一层级中 代码案例 发送数据 package com.hidata.devops.paas.udp;import java.io.IOException; …

图形处理软件Photoshop Elements 2020 mac中文版 ps简化版

Photoshop Elements 2020 mac是一款非常实用的图形处理工具。ps elements 2020 mac中文版可以帮助您自动生成照片和视频作品的功能&#xff0c;采用Adobe Sensei AI技术可进行图像组织、编辑和创建等。Photoshop Elements 2020 for Mac激活版可以帮助您轻松整理照片和视频&…

【springboot3.x 记录】关于Jakarta包无法引入的问题

最近想将一些项目升级到springboot3.x和java17的时候&#xff0c;发现项目依赖中有Jakarta的包&#xff0c;但是代码标红提示没有相关的类&#xff0c;特此记录一下排查问题和最终解决问题的思路方法 一、发现问题 因为之前有创建过 springboot3.x java17 的项目&#xff0c;…

php导出cvs,excel打开数字超过16变科学计数法

今天使用php导出cvs&#xff0c;在excel中打开&#xff0c;某一个字段是数字&#xff0c;长度高于16位结果就显示科学计数法 超过15位的话从第16位开始就用0代替了 查询了半天总算解决了就是在后面加上"\t" $data[$key][1] " ".$value[1]."\t";…

法规标准-UN R48标准解读

UN R48是做什么的&#xff1f; UN R48全名为关于安装照明和灯光标志装置的车辆认证的统一规定&#xff0c;主要描述了对各类灯具的布置要求及性能要求&#xff1b;其中涉及自动驾驶功能的仅有6.25章节【后方碰撞预警信号】&#xff0c;因此本文仅对此章节进行解读 功能要求 …

Mysql编译安装和yum安装

一、msql数据库介绍 1、什么是sql sql代表结构化查询语言&#xff0c;sql是用于访问数据库的标椎化语言 sql包含三个部分 DDL数据定义语言包含定义数据库及其对象的语言&#xff0c;例如表&#xff0c;视图&#xff0c;触发器&#xff0c;存储过程等 DML数据操作语言包含允许数…

windows 修改hosts映射,可以ping通,但是无法通过http url 路径访问,出现 500 Internal Privoxy Error

问题描述 今天在学习nginx时&#xff0c;想在hosts配置一个nginx的域名映射&#xff0c;但是发现访问nginx服务的ip时可以访问通&#xff0c;在dos命令窗口ping配置的域名映射也可以ping通&#xff0c;但是一旦在浏览器通过http请求访问配置的hosts域名映射时却出现 500 Inter…

学习:原码-反码-补码

文章目录 前提知识原码详解反码补码 二进制负数的运算 前提知识 正数不需要进行原码反码补码一说&#xff0c;正数就是正数&#xff0c;我们原码反码补码是为了针对负数 &#xff08;按道理来说其实根本不存在什么码&#xff0c;只有二进制机器码&#xff0c;不过是为了方便计…

【Java 基础篇】Java 实现模拟斗地主游戏

欢迎阅读本篇博客&#xff0c;在这篇博客中&#xff0c;我们将详细讲解如何使用Java编写一个简单的模拟斗地主游戏。这个项目将帮助您了解Java编程中的一些基本概念&#xff0c;如面向对象编程、集合框架的使用、随机数生成等。 引言 斗地主是一种非常受欢迎的纸牌游戏&#…