将添加功能的抽屉剥离,在父组件调用思路

一、新建组件

新建AddRoleEditerDrawer.vue
<template><div><el-drawer v-model="dialog" title="添加角色" :before-close="handleClose" direction="rtl" @colse="cancelForm"class="demo-drawer" modal-class="add-drawer"><div class="drawerContent"><!-- 表单 --><el-form ref="ruleFormRef" :model="ruleForm" :rules="rules"><el-form-item prop="roleName" label="角色名:" :label-width="formLabelWidth"><el-input v-model="ruleForm.roleName" autocomplete="off" /></el-form-item><!-- 按钮 --><el-form-item :label-width="formLabelWidth"><el-button @click="cancelForm">取消</el-button><el-button type="primary" :loading="loading" @click="submitFom(ruleFormRef)">{{ loading ? '提交中 ...' : '提交' }}</el-button></el-form-item></el-form></div></el-drawer></div></template>
1. 这里定义了抽屉的dialog,这个变量是控制抽屉打开和关闭的。
2. 定义了:before-close,这个参数控制抽屉关闭前的动作,一般是用来清空表单
3. 定义了@close,这个参数,在关闭时进行一些操作
4. 其他的是表单内容,可以自定义修改

二、添加ts

<script setup lang="ts">import { reactive, ref } from 'vue'import { ElDrawer, ElMessage, ElMessageBox } from 'element-plus'import type { FormInstance, FormRules } from 'element-plus';import { $updateRole, $addRole } from '../../api/role.ts'import { useRoute } from 'vue-router';const formLabelWidth = '80px'const route = useRoute()const ruleFormRef = ref<FormInstance>()const ruleForm = ref({roleId: null,roleName: ''})const dialog = ref(false)const loading = ref(false)// 控制表单规则const validRoleNames = (rule: any, value: any, callback: any) => {if (value === '') {// 清除定时器loading.value = falsecallback(new Error('角色名不能为空'))} else {callback()}}// 定义规则const rules = ref<FormRules<typeof ruleForm>>({roleName: [{ validator: validRoleNames, trigger: 'blur' }]})// 清空表单const resetForm = () => {ruleForm.value = {roleId: null,roleName: ''}}// 定义传入父组件对象,const emit = defineEmits(['success'])const submitFom = (FormEl?: FormInstance | undefined) => {loading.value = true// 提交添加角色,获取结果if (!FormEl) return trueFormEl.validate(async (valid) => {if (valid) {let ret = await $addRole(ruleForm.value)if (ret.code == 200) {ElMessage.success(ret.msg)resetForm()loading.value = falsedialog.value = falseemit('success', 'add')}else {ElMessage.error(`code: ${ret.code}  信息:${ret.msg}`)}}else {return false}})}const handleClose = (done) => {if (loading.value) {return}ElMessageBox.confirm('您想要提交再关闭吗?').then(() => {loading.value = true// 提交结果let ret = submitFom(ruleFormRef.value)if (ret) {loading.value = falsedone()}}).catch(() => {dialog.value = falseElMessage.error('用户取消提交')ruleForm.value = {roleId: null,roleName: ''}// catch error})}// 关闭抽屉const cancelForm = () => {loading.value = falsedialog.value = falseresetForm()// clearTimeout(timer)}// 打开抽屉const open = (obj: any) => {dialog.value = true}defineExpose({open})</script>
这里暴露了一个open方法,参数是obj,如果想从父组件传值过来,可以通过obj传,比如编辑表单,则需要传入对应的值,这里的obj就可以收到值,从而反应到表单中。如果不传值,就直接传个空对象即可

三、父组件设置

在合适的位置添加抽屉组件
<!-- 角色添加抽屉 --><AddRoleEdiderDrawer ref="AddRoleRef" @success="onSuccess"></AddRoleEdiderDrawer>
这里设置了两个参数,一个是ref=AddRoleRef,这个值,可以获取暴露的方法open
这个success可以同步方法处理结果,比如子组件在提交的时候传来了emit('success', 'add'),此时就可以根据这个add的类型,更新分页器组件,如果增加了新页,就可以更新当前页。1.打开抽屉操作
	// 定义子组件暴露出的方法对象const AddRoleRef = ref()// 打开抽屉const handleAdd = () => {// 传入空值,则此时子组件的obj参数是空对象,可以通过判断来采取对应的操作AddRoleRef.value.open({})}
2.处理添加页面后的分页操作
	// 处理添加和编辑后的页面刷新const onSuccess = (type:any) => {if (type === 'add') {// 调用分页器暴露出来的方法,处理当前页面变化pageRef.value.handleChange()}}

在这里插入图片描述

结果就是这样,当添加角色后,页面会发生对应的变化
在这里插入图片描述

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

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

相关文章

「数学::质数」试除法 / Luogu P5736(C++)

概述 在质数的第一节我们来讲解试除法。 质数是指在大于1的自然数中只能被1和它自己整除的数。 我们可以利用这一除法性质对质数进行判定。 Luogu P5736&#xff1a; 输入 n 个不大于 10^5 的正整数。要求全部储存在数组中&#xff0c;去除掉不是质数的数字&#xff0c;依…

LLM Attention and Rotary Position Embedding(旋转位置编码)

旋转位置编码&#xff08;Rotary Position Embedding&#xff0c;RoPE&#xff09;是一种能够将相对位置信息依赖集成Attention计算里的方法。就是在做词表映射的时候不是单一的进行一个embedding计算&#xff0c;还考虑位置信息。 一些资料 [1] https://arxiv.org/pdf/2104.0…

面对养老困局我心安若素

“2025年&#xff0c;我们需要注意什么&#xff1f;是复杂的国际环境么&#xff1f;明年对于我国70岁以上的老年人来说这可不是主要关心的问题。反而有这两件事情需要他们来关注&#xff0c;如果70岁老人不提前做好准备&#xff0c;可能会有非常严重的后果......”这是昨天发表…

鸿蒙轻内核M核源码分析系列十五 CPU使用率CPUP

往期知识点记录&#xff1a; 鸿蒙&#xff08;HarmonyOS&#xff09;应用层开发&#xff08;北向&#xff09;知识点汇总 轻内核M核源码分析系列一 数据结构-双向循环链表 轻内核M核源码分析系列二 数据结构-任务就绪队列 鸿蒙轻内核M核源码分析系列三 数据结构-任务排序链表 轻…

国产脑机全面超越马斯克Nearlink

&#x1f4a5;&#x1f4a5;&#x1f4a5;刚刚&#xff0c;世界首富马斯克同学已经是完全懵逼了&#xff0c;心态都崩了&#xff01;因为今天爆出来了一个轰动了全世界科技界的大新闻&#xff0c;国产脑机在多个维度上全面超越了马斯克的Nearlink&#xff01; &#x1f4a5;&am…

SpringBoot2:请求处理原理分析-RESTFUL风格接口

一、RESTFUL简介 Rest风格支持&#xff08;使用HTTP请求方式&#xff0c;动词来表示对资源的操作&#xff09; 以前&#xff1a;/getUser 获取用户 /deleteUser 删除用户 /editUser 修改用户 /saveUser 保存用户 现在&#xff1a; /user GET-获取用户 DELETE-删除用户 PUT-修改…

数据仓库技术选型方案文档

关联博客&#xff1a; 数据仓库技术选型方案文档 Flink CDC MySQL数据同步到Doris表同步配置生成工具类 新版报表系统&#xff08;明细报表、看板、数据大屏&#xff09;方案&介绍 文章目录 数据仓库技术选型背景现状现状架构目标架构业务反馈&痛点问题&#xff1a;原因…

随手记:小程序体积超出2M包大小如何优化

小程序的包体积限制是2M&#xff0c;超出包大小如何优化 先简单列出&#xff0c;最近比较忙&#xff0c;后续优化明细&#xff0c;有着急的先留言踢我 1.分包 留几个主要的页面体积小的&#xff0c;剩下的在page.json中拆到subpackages中&#xff0c;简单举个例子 "page…

多维动态规划-面试高频!-最长公共子序列和最长公共子串、回文串-c++实现和详解

1143. 最长公共子序列 中等 给定两个字符串 text1 和 text2&#xff0c;返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 &#xff0c;返回 0 。 一个字符串的 子序列 是指这样一个新的字符串&#xff1a;它是由原字符串在不改变字符的相对顺序的情况下删…

力扣1049-最后一块石头的重量II(Java详细题解)

题目链接&#xff1a;1049. 最后一块石头的重量 II - 力扣&#xff08;LeetCode&#xff09; 前情提要&#xff1a; 因为本人最近都来刷dp类的题目所以该题就默认用dp方法来做。 最近刚学完01背包&#xff0c;所以现在的题解都是以01背包问题为基础再来写的。 如果大家不懂…

FPGA实现串口升级及MultiBoot(二)FPGA启动流程

这个系列开篇肯定要先了解FPGA的启动流程&#xff0c;试想一下&#xff1a;我想实现MultiBoot&#xff0c;那么我应该在什么时候开始升级&#xff0c;升级失败后FPGA进行了哪些操作&#xff0c;以及怎么回到Golden区&#xff1f; 还有一个问题&#xff0c;就是我硬件打板回来&a…

Selenium 实现图片验证码识别

前言 在测试过程中&#xff0c;有的时候登录需要输入图片验证码。这时候使用Selenium进行自动化测试&#xff0c;怎么做图片验证码识别&#xff1f;本篇内容主要介绍使用Selenium、BufferedImage、Tesseract进行图片 验证码识别。 环境准备 jdk&#xff1a;1.8 tessdata&…

深度学习--对抗生成网络(GAN, Generative Adversarial Network)

对抗生成网络&#xff08;GAN, Generative Adversarial Network&#xff09;是一种深度学习模型&#xff0c;由Ian Goodfellow等人在2014年提出。GAN主要用于生成数据&#xff0c;通过两个神经网络相互对抗&#xff0c;来生成以假乱真的新数据。以下是对GAN的详细阐述&#xff…

如果电脑一直提示微软账号登录……

前言 今天小白接了个电脑故障问题&#xff1a;电脑提示微软账号登录&#xff0c;然后经过各种操作…… 电脑重启之后就变成了这样&#xff1a; 按理说&#xff0c;登录了微软账号之后&#xff0c;Windows系统要进入到桌面就必须有一个输入密码验证的过程&#xff0c;但这个界…

Harmony OS DevEco Studio 如何导入第三方库(以lottie为例)?-- HarmonyOS自学2

在做鸿蒙开发时&#xff0c;离不开第三方库的引入 一.有哪些支持的Harmony OS的 第三方库&#xff1f; 第三方库下载地址&#xff1a; 1 tpc_resource: 三方组件资源汇总 2 OpenHarmony三方库中心仓 二. 如何加入到DevEco Studio工程 以 lottie为例 OpenHarmony-TPC/lot…

nginx 新建一个 PC web 站点

注意&#xff1a;进行实例之前必须完成nginx的源码编译。&#xff08;阅读往期文章完成步骤&#xff09; 1.编辑nginx的配置文件&#xff0c;修改内容 [rootlocalhost ~]# vim /usr/local/nginx/conf/nginx.conf 2.创建新目录/usr/local/nginx/conf.d/&#xff0c;编辑新文件…

基于飞腾平台的Hive的安装配置

【写在前面】 飞腾开发者平台是基于飞腾自身强大的技术基础和开放能力&#xff0c;聚合行业内优秀资源而打造的。该平台覆盖了操作系统、算法、数据库、安全、平台工具、虚拟化、存储、网络、固件等多个前沿技术领域&#xff0c;包含了应用使能套件、软件仓库、软件支持、软件适…

通信工程学习:什么是PCM脉冲编码调制、DPCM差分脉冲编码调制、ADPCM自适应差分脉冲编码调制

PCM脉冲编码调制、DPCM差分脉冲编码调制、ADPCM自适应差分脉冲编码调制 PCM、DPCM、ADPCM是音频编码技术中的三种重要方式&#xff0c;它们在音频信号的数字化、压缩和传输中起着关键作用。以下是对这三种技术的详细解释&#xff1a; 一、PCM&#xff08;Pulse Code Modulatio…

2024数学建模国赛选题建议+团队助攻资料(已更新完毕)

目录 一、题目特点和选题建议 二、模型选择 1、评价模型 2、预测模型 3、分类模型 4、优化模型 5、统计分析模型 三、white学长团队助攻资料 1、助攻代码 2、成品论文PDF版 3、成品论文word版 9月5日晚18&#xff1a;00就要公布题目了&#xff0c;根据历年竞赛题目…

[C#学习笔记]注释

官方文档&#xff1a;Documentation comments - C# language specification | Microsoft Learn 一、常用标记总结 1.1 将文本设置为代码风格的字体&#xff1a;<c> 1.2 源代码或程序输出:<code> 1.3 异常指示:<exception> 1.4 段落 <para> 1.5 换行&…