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

2024-09-08 05:20

本文主要是介绍将添加功能的抽屉剥离,在父组件调用思路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、新建组件

新建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.chinasem.cn/article/1147225

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

SpringCloud使用Nacos 配置中心实现配置自动刷新功能使用

《SpringCloud使用Nacos配置中心实现配置自动刷新功能使用》SpringCloud项目中使用Nacos作为配置中心可以方便开发及运维人员随时查看配置信息,及配置共享,并且Nacos支持配... 目录前言一、Nacos中集中配置方式?二、使用步骤1.使用$Value 注解2.使用@Configur