优雅的使用element-plus的dialog-[从零开始vue3+vite+ts+pinia+router4后台管理(9)

优雅的使用element-plus的dialog-[从零开始vue3+vite+ts+pinia+router4后台管理(9)

代码gitee地址

在线预览

系列文章

从零开始vue3+vite+ts+pinia+router4后台管理(1)

从零开始vue3+vite+ts+pinia+router4后台管理(2)-页面布局

从零开始vue3+vite+ts+pinia+router4后台管理(3)-动态路由

从零开始vue3+vite+ts+pinia+router4后台管理(4)-导航标签栏和keep-alive缓存

从零开始vue3+vite+ts+pinia+router4后台管理(5)-二次封装表格1.0

从零开始vue3+vite+ts+pinia+router4后台管理(6)-全局自定义指令实现节流与防抖

什么才是完美的表格二次封装elementPlus表格?-从零开始vue3+vite+ts+pinia+router4后台管理(7)

elementPlus-Form封装动态表单-从零开始vue3+vite+ts+pinia+router4后台管理(8)

bash 复制代码
# 克隆项目 gitee地址
git clone https://gitee.com/3439/Spurs-Admin.git
​
# 进入项目目录
cd Spurs-Admin
​
# 安装依赖
npm install
​
# 本地开发 启动项目
npm run dev

1.解决使用dialog的什么问题?

1.解决引入Dialog去定义一个visible变量

2.减少一些重复的dom,比如每个dialog都带有的确定和取消

3.统一去配置elementPlus的Dialog的api

2.基于 el-dialog 进行初步封装

html 复制代码
<template>
  <div class="spurs-dialog">
    <el-dialog
        v-bind="$attrs"
        v-model="dialogVisible"
        :append-to-body="true"
        :close-on-click-modal="false"
        :close-on-press-escape="false"
        draggable
        >
      <slot name="body"></slot>
      <template #footer>
      <span class="dialog-footer">
        <el-button @click="dialogVisible=false">取消</el-button>
        <el-button  v-if="dialogType!='readonlyDialog'" type="primary" @click="saveSubmit">
          确 定
        </el-button>
      </span>
      </template>
      <slot name="footer"></slot>
    </el-dialog>
  </div>
</template>
<script setup lang="ts">
import {ref} from "vue";
let dialogVisible = ref(false)
defineExpose({
  dialogVisible
})
const props = defineProps({
  dialogType: {type:String, default:""}//默认有确定和取消readonlyDialog展示dialog只有取消
});
const close = () =>{
  dialogVisible.value = false
}
const emit = defineEmits(['saveSubmit'])
const saveSubmit = () => {
  emit('saveSubmit');
}
</script>

1.首先用v-bind="$attrs"去接收elementPlus 所有父组件使用的 api等

2.用defineExpose把控制显示隐藏的dialogVisible暴露出去,让父组件去控制

3.定义dialog的类型 默认都有 确定和取消按钮 但是有的dialog只有展示功能 定义readonlyDialog的时候只有取消按钮,然后定义一个footer的插槽来定义特殊的情况

4.通过defineEmits 定义确定按钮saveSubmit事件,让父组件去接收

使用

html 复制代码
<template>
  <div class="simple-dialog">
    <el-button @click="spursDialogRef.dialogVisible = true">打开dialog</el-button>
    <spurs-dialog
        ref="spursDialogRef"
        :title="title"
        @saveSubmit="saveSubmit"
    >
      <template #body>
        <span>我是dialog111</span>
      </template>
      <template #footer>
        <el-button type="success" @click="spursDialogRef.dialogVisible = true">我是操作2</el-button>
      </template>
    </spurs-dialog>
  </div>
</template>
<script setup lang="ts">
import SpursDialog from '@/components/SpursDialog/index.vue'
import {ref} from "vue";
let title = ref('提示')
const spursDialogRef = ref <any> ()
const saveSubmit = () => {
  console.log("点击了确定按钮")
}
</script>

3.一个页面多个dialog的情况

定义不同的ref

html 复制代码
<template>
  <div class="simple-dialog">
    <el-button @click="spursDialogRef.dialogVisible = true">打开dialog</el-button>
    <el-button @click="spursDialogRef2.dialogVisible = true">打开dialog2</el-button>
    <spurs-dialog
        ref="spursDialogRef"
        :title="title"
        @saveSubmit="saveSubmit"
    >
      <template #body>
        <span>我是dialog111</span>
      </template>
      <template #footer>
        <el-button type="success" @click="spursDialogRef.dialogVisible = true">我是操作2</el-button>
      </template>
    </spurs-dialog>
    <spurs-dialog
        ref="spursDialogRef2"
        :title="title"
        :dialogType="dialogType"
    >
      <template #body>
        <span>我是dialog2222</span>
      </template>
    </spurs-dialog>

  </div>
</template>
<script setup lang="ts">
import SpursDialog from '@/components/SpursDialog/index.vue'
import {ref} from "vue";
let dialogType = ref('readonlyDialog')
let title = ref('提示')
const spursDialogRef = ref <any> ()
const spursDialogRef2 = ref <any> ()
const saveSubmit = () => {
  console.log("点击了确定按钮")
}
</script>

4 嵌套的对话框

html 复制代码
<template>
  <div class="simple-dialog">
    <el-button @click="spursDialogRef.dialogVisible = true">打开dialog</el-button>

    <spurs-dialog
        ref="spursDialogRef"
        :title="title"
        width="900"
        @saveSubmit="saveSubmit"
    >
      <template #body>
        <span>我是dialog111</span>
        <br>
        <el-button @click="spursDialogRef2.dialogVisible = true">打开内层 Dialog</el-button>
        <spurs-dialog
            ref="spursDialogRef2"
            :title="title"
            @saveSubmit="saveSubmitInner"
        >
          <template #body>
            <span>我是内层 Dialog222222222</span>
          </template>
        </spurs-dialog>
      </template>
      <template #footer>
        <el-button type="success" @click="spursDialogRef.dialogVisible = true">我是操作2</el-button>
      </template>
    </spurs-dialog>


  </div>
</template>
<script setup lang="ts">
import SpursDialog from '@/components/SpursDialog/index.vue'
import {ref} from "vue";
let dialogType = ref('readonlyDialog')
let title = ref('提示')
const spursDialogRef = ref <any> ()
const spursDialogRef2 = ref <any> ()
const saveSubmit = () => {
  console.log("点击了确定按钮")
}
const saveSubmitInner = () => {
  console.log("点击了内层确定按钮")
}
</script>

5.全局使用dialog

最后在main.ts文件进行注册即可使用

typescript 复制代码
import SpursDialog from '@/components/SpursDialog/index.vue'//引入dialog组件
app.component('SpursDialog', SpursDialog)//注册dialog
相关推荐
neter.asia8 分钟前
vue中如何关闭eslint检测?
前端·javascript·vue.js
~甲壳虫8 分钟前
说说webpack中常见的Plugin?解决了什么问题?
前端·webpack·node.js
十一吖i26 分钟前
前端将后端返回的文件下载到本地
vue.js·elementplus
光影少年27 分钟前
vue2与vue3的全局通信插件,如何实现自定义的插件
前端·javascript·vue.js
As977_28 分钟前
前端学习Day12 CSS盒子的定位(相对定位篇“附练习”)
前端·css·学习
susu108301891130 分钟前
vue3 css的样式如果background没有,如何覆盖有background的样式
前端·css
Ocean☾32 分钟前
前端基础-html-注册界面
前端·算法·html
Rattenking32 分钟前
React 源码学习01 ---- React.Children.map 的实现与应用
javascript·学习·react.js
Dragon Wu34 分钟前
前端 Canvas 绘画 总结
前端
CodeToGym39 分钟前
Webpack性能优化指南:从构建到部署的全方位策略
前端·webpack·性能优化