使用element中el-cascader级联选择器动态懒加载以及回显 (单选)

news2025/1/22 9:26:10
<template>
    <!-- 新增||修改弹框 -->
    <el-dialog :close-on-click-modal="false" :close-on-press-escape="false" :title="title" :visible.sync="open"
        width="800px" append-to-body>
        <el-form ref="form" :model="form" label-width="80px">
            <el-form-item label="地址:" prop="addressId">
                <el-cascader v-if="open" v-model="form.addressId" :props="props" :options="options"
                    :placeholder="addressName" />
            </el-form-item>
        </el-form>
        <div slot="footer" class="dialog-footer">
            <el-button type="primary" @click="submitForm">确 定</el-button>
            <el-button @click="cancel">取 消</el-button>
        </div>
    </el-dialog>
</template>
<script>
// 导入接口 (根基实际项目,自定义)
import { lazyList, getUser, updateUser, addUser } from '@/api/manager/user'
var uploadingClick = 0
export default {
    data() {
        return {
            title: '',
            open: false,
            options: [],
            //     options:[  // 级联选择器的数据格式
            // 		{
            // 		"ancestors": "0,100", // 上级的deptId以逗号分割形成的字符串
            // 		"deptName": "测试1",
            // 		"deptId": 25438,
            // 		"parentId": 100,
            // 		"parentName": "测试",
            // 		"existSub": true  
            // 	},
            // 	{
            // 		"ancestors": "0,100",
            // 		"deptName": "测试2",
            // 		"deptId": 25441,
            // 		"parentId": 100,
            // 		"parentName": "测试",
            // 		"existSub": false
            // 	},
            //    ],
            addressName: '请选择',  //当前选中的name
            form: {
                addressId: [], //选中的上下级deptId所组成的数组:比如:  [100, 25438, 25519, 25652, 25604] ,
            },
            // 表单校验
            rules: {
                addressId: [
                    {
                        required: true,
                        message: '地址不能为空',
                        trigger: 'blur'
                    }
                ],
            },
            props: {
                //是否动态加载子节点,需与 lazyLoad 方法结合使用
                lazy: true,
                value: 'deptId',
                label: 'deptName',
                children: 'children',
                //在选中节点改变时,是否返回由该节点所在的各级菜单的值所组成的数组,若设置 false,则只返回该节点的值
                emitPath: false,
                //是否严格的遵守父子节点不互相关联
                checkStrictly: true,
                //加载动态数据的方法,仅在 lazy 为 true 时有效
                //function(node, resolve),node为当前点击的节点,resolve为数据加载完成的回调(必须调用)
                lazyLoad(node, resolve) {
                    const queryParams = {}
                    queryParams.parentId = node.value
                    //根据parentId 查询下级的数据
                    lazyList(queryParams).then(res => {
                        res.data.forEach(item => { // 是否存在下级,是否禁用
                            item.leaf = !item.existSub
                            item.disabled = false
                        })
                        resolve(res.data)
                    })
                }
            },
        }
    },

    methods: {
        // 表单重置
        reset() {
            this.form = {
                addressId: [],
            }
            this.resetForm('form')
        },
        /** 新增操作 */
        handleAdd() {
            this.reset()
            this.open = true
            this.title = '添加'
        },
        /** 修改操作 */
        handleUpdate(row) {
            this.reset()
            const id = row.id
            // 调用详情的接口
            getUser(id).then(response => {
                this.form = response.data
                // 处理addressId ,用来获取所有上下级deptId组成的数组
                this.form.addressId = this.dataEchoHandle(response.data)
                this.open = true
                this.title = '修改'
            })
        },

        // Cascader 级联选择器 懒加载  数据回显
        dataEchoHandle(row) { // 
            // 获取到当前的addressId
            let ancestors = row.addressId // 当前的id,比如:25604
            if (row.ancestors && row.ancestors != '') { // 格式:'0,100, 25438, 25519, 25652'
                // 对数据进行回显(获取所有父级的addressId,加上当前的addressId,组成的数组。)
                ancestors = row.ancestors.split(',')
                ancestors.shift() //去掉0
                ancestors = ancestors.map(Number) // 数组的每个元素由string转为number类型
                ancestors.push(row.addressId) // 将当前的id加入
                console.log(ancestors, 'ancestors')  // 获取到所有的id组成的数组  [100, 25438, 25519, 25652, 25604] 
            }
            return ancestors
        },
        // 取消按钮
        cancel() {
            this.open = false
            this.reset()
        },
        /** 提交按钮 */
        submitForm: function () {
            if (uploadingClick == 0) {
                uploadingClick = 1
                this.$refs['form'].validate(valid => {
                    if (valid) {
                        console.log('this.form', this.form)
                        const params = JSON.parse(JSON.stringify(this.form))
                        // return;
                        if (this.form.id != undefined) {
                            if (params.addressId instanceof Array) {
                                // 数组类型
                                params.addressId = params.addressId[params.addressId.length - 1]
                            }
                            console.log('params修改', params)
                            // return;
                            updateUser(params).then(response => {
                                this.$modal.msgSuccess('修改成功')
                                this.open = false
                            })
                        } else {
                            addUser(params).then(response => {
                                this.$modal.msgSuccess('新增成功')
                                this.open = false
                            })
                        }
                    }
                })
                setTimeout(function () {
                    uploadingClick = 0
                }, 3000)
            } else {
                this.$modal.msgError('请勿重复点击')
            }
        },
    }
}
</script>

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

Unity | 快速修复Animation missing错误

目录 一、背景 二、效果 三、解决办法 一、背景 最近在做2D 骨骼动画相关的Demo&#xff0c;我自己使用Unity引擎进行骨骼绑定并创建了anim后&#xff0c;一切正常&#xff0c;anim也能播放。但是昨天我修改Obj及子物体的名称&#xff08;由中文改为英文&#xff0c;如&…

RabbitMQ 核心概念(交换机、队列、路由键),队列类型等介绍

RabbitMQ 核心概念(交换机、队列、路由键)&#xff0c;队列类型等介绍 RabbitMQ 是一个消息队列系统&#xff0c;它的核心概念包括交换机&#xff08;Exchange&#xff09;、队列&#xff08;Queue&#xff09;和路由键&#xff08;Routing Key&#xff09;&#xff0c;它们一起…

OpenStack云计算(-) 简介与部署Keystone

一.OpenStack简介 什么是云计算:云计算是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问,进入可配置的计算资源共享池(资源包括网络,服务器,存储,应用软件,服务) 云计算所包含的几个层次服务&#xff1a; SaaS ( Software as a Service ) :把在线软件作…

LLM提示词工程学习_Day01

LLM提示词工程学习_Day01 安装学习环境基础Conda环境安装安装Python安装所需的包Jupyter Notebook 安装获取OpenAI API KEY&#xff0c;并写入工程目录里的.env文件进入Jupyter&#xff0c;先跑一段代码 安装学习环境 基础Conda环境安装 conda环境安装&#xff0c;miniconda也…

omlox定位标准(二)——定位核心

上一篇文章中介绍了关于omlox hub相关内容&#xff0c;可以用于整合多种API接口&#xff0c;便于实现统一的应用&#xff0c;本文中介绍omlox core&#xff0c;介绍了基础设施、定位技术、定位引擎等内容。 2.omlox core zone and air-interface 随着越来越多的业务应用基于室…

基于ssm的航空票务推荐系统的设计与实现论文

摘 要 传统信息的管理大部分依赖于管理人员的手工登记与管理&#xff0c;然而&#xff0c;随着近些年信息技术的迅猛发展&#xff0c;让许多比较老套的信息管理模式进行了更新迭代&#xff0c;航班信息因为其管理内容繁杂&#xff0c;管理数量繁多导致手工进行处理不能满足广大…

[C++] : 贪心算法专题(第一部分)

1.柠檬水找零&#xff1a; 1.思路一&#xff1a; 柠檬水找零 class Solution { public:bool lemonadeChange(vector<int>& bills) {int file0;int ten 0;for(auto num:bills){if(num 5) file;else if(num 10){if(file > 0)file--,ten;elsereturn false;}else{i…

读算法霸权笔记07_筛选

1. 美国残疾人法案 1.1. 1990年 1.2. 公司在招聘时使用身体检查是非法的 1.3. 有某些心理健康问题的人被“亮了红灯”&#xff0c;他们因此没能找到一份正常的工作&#xff0c;过上正常的生活&#xff0c;这就使其进一步被社会孤立&#xff0c;而这正是《美国残疾人法案》要…

万界星空低代码云MES-才是工业MES的未来

万界星空科技作为一家在云MES系统的研发、生产自动化方面拥有很多年行业经验的科技型企业&#xff0c;多年来专注于云MES系统的研发与技术支持服务&#xff0c;目前已成为国内知名的智能制造整体解决方案提供商。 近几年&#xff0c;万界星空科技发掘制造行业生产及物流难点、…

算法基础之蒙德里安的梦想

蒙德里安的梦想 核心思想&#xff1a; 状态压缩dp 总方案 横放的方案 剩下的地方竖着放是固定的了 状态压缩 &#xff1a; 将每一列的图(横终点 横起点 竖) 用一个二进制数存下 向后凸的为1 反之为0 状态计算&#xff1a; 所有 i – 1 列 不冲突的 都加和 f[i , j] f[i - 1…

三个故事,谈谈小米汽车技术发布会

都说新年新气象&#xff0c;随着年末消费旺季到来&#xff0c;汽车市场越来越热闹了。 继蔚来12月23日公布旗舰车型ET9&#xff0c;华为26日发布问界M9&#xff0c;小米汽车首款量产车型SU7终于正式亮相。 12月28日&#xff0c;在小米汽车技术发布会上&#xff0c;小米创办人…

Apache Flink连载(二十一):Flink On Yarn运行原理-Yarn Application模式

🏡 个人主页:IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客 🚩 私聊博主:加入大数据技术讨论群聊,获取更多大数据资料。 🔔 博主个人B栈地址:豹哥教你大数据的个人空间-豹哥教你大数据个人主页-哔哩哔哩视频 目录 1. 任务提交命令

SpringBoot 实现Execl 导入导出

1、引包 <dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-base</artifactId><version>3.0.3</version></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easy…

基于element-ui table组件的二次封装

文章目录 配置数据基础分析封装 el-table-column使用插槽强化结语 相信 element-ui 大家都有所耳闻&#xff0c;table 也是老朋友了&#xff0c;不过在使用它的时候大家是怎么使用的呢&#xff1f;是直接在官网上cv使用吗&#xff1f;这种方式&#xff0c;我相信写起来会有点小…

[2024] 十大免费电脑数据恢复软件——轻松恢复电脑上已删除文件

哈喽大家好&#xff01;你有没有需要适用于电脑的免费数据恢复软件呢&#xff1f;数据丢失可是个烦心事&#xff0c;无论是硬件故障还是软件损坏&#xff0c;甚至是意外删除、格式化或计算机病毒&#xff0c;都让人郁闷至极。当你遇到数据丢失的情况时&#xff0c;你一定希望能…

基于huffman编解码的图像压缩算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 Huffman编码算法步骤 4.2 Huffman编码的数学原理 4.3 基于Huffman编解码的图像压缩 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ..…

在Linux上搭建Maven仓库的实战教程

引言 在Java开发中&#xff0c;Maven作为项目构建和依赖管理的重要工具&#xff0c;其仓库的搭建至关重要。本文将手把手教你如何在Linux系统上安装并配置Nexus Repository Manager 3&#xff08;简称Nexus 3&#xff09;&#xff0c;从而创建一个私有的Maven仓库。 步骤一&a…

浅谈水下起重顶升作业使用千斤顶的可能性

并非所有起重顶升的施工环境全为常规环境&#xff0c;除了传统的陆上作业之外&#xff0c;难免也会有一些特殊环境下的起重顶升任务&#xff0c;其中比较典型的自然是水下起重顶升作业&#xff0c;那么千斤顶究竟能在水下进行起重顶升作业吗&#xff1f;接下来成华制造来给大家…

04-获取认证的用户身份信息

存储用户信息的方式 获取用户信息的流程 用户提交账号和密码后,DaoAuthenticationProvider调用UserDetailsService接口实现类的loadUserByUsername()方法,该方法可以接收请求参数username的值,然后根据该值查询用户信息,最后将账号,密码,权限封装到UserDetails对象中并返回给…

I.MX6ULL_Linux_驱动篇(51)linux 音频驱动

音频是我们最常用到的功能&#xff0c;音频也是 linux 和安卓的重点应用场合。 I.MX6ULL 带有 SAI接口&#xff0c;正点原子的 I.MX6ULLALPHA 开发板通过此接口外接了一个 WM8960 音频 DAC 芯片&#xff0c;本章我们就来学习一下如何使能 WM8960 驱动&#xff0c;并且通过 WM89…