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

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

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

三相直流无刷电机(BLDC)控制算法实现:BLDC有感启动算法思路分析

一枚从事路径规划算法、运动控制算法、BLDC/FOC电机控制算法、工控、物联网工程师,爱吃土豆。如有需要技术交流或者需要方案帮助、需求:以下为联系方式—V 方案1:通过霍尔传感器IO中断触发换相 1.1 整体执行思路 霍尔传感器U、V、W三相通过IO+EXIT中断的方式进行霍尔传感器数据的读取。将IO口配置为上升沿+下降沿中断触发的方式。当霍尔传感器信号发生发生信号的变化就会触发中断在中断