Skip to content

对话框 Dialog

弹出的对话框

何时使用

  • 在当前页面正中打开一个浮层,承载相应的操作或者展示内容

基本使用

Open Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
function openDialog() {
  open = true
}
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open.value = false
}
</script>
<template>
  <Button type="primary" @click="openDialog">Open Dialog</Button>
  <Dialog v-model:open="open" title="Title" @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

自定义宽高

Open Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
function openDialog() {
  open = true
}
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open.value = false
}
</script>
<template>
  <Button type="primary" @click="openDialog">Open Dialog</Button>
  <Dialog v-model:open="open" :width="480" :height="200" @cancel="onCancel" @ok="onOk">
    <template #title>Title</template>
    <p>Some contents...</p>
    <p>Some contents...</p>
    <p>Some contents...</p>
    <p>Some contents...</p>
    <p>Some contents...</p>
    <p>Some contents...</p>
  </Dialog>
</template>

自定义样式

Custom Body Class Dialog
Custom Body & Mask Style Dialog
Custom Title & Content Style Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open1 = ref(false)
const open2 = ref(false)
const open3 = ref(false)
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open1.value = false
  open2.value = false
  open3.value = false
}
</script>
<template>
  <Space>
    <Button type="primary" @click="open1 = true">Custom Body Class Dialog</Button>
    <Button type="primary" @click="open2 = true">Custom Body & Mask Style Dialog</Button>
    <Button type="primary" @click="open3 = true">Custom Title & Content Style Dialog</Button>
  </Space>
  <Dialog v-model:open="open1" title="Title" body-class="custom-class" @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
  <Dialog
    v-model:open="open2"
    title="Title"
    :body-style="{
      padding: '24px',
      borderRadius: '16px'
    }"
    :mask-style="{
      backgroundColor: 'rgba(0, 0, 0, 0.6)'
    }"
    @cancel="onCancel"
    @ok="onOk"
  >
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
  <Dialog
    v-model:open="open3"
    title="Title"
    :title-style="{
      fontSize: '18px',
      color: '#d4380d'
    }"
    :content-style="{
      fontSize: '16px',
      color: '#d4380d'
    }"
    @cancel="onCancel"
    @ok="onOk"
  >
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>
<style lang="less" scoped>
:deep(.custom-class) {
  .dialog-header {
    color: #ff6900 !important;
  }
  .dialog-content {
    color: #ff6900 !important;
  }
}
</style>

自定义按钮

Custom Btns Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
function openDialog() {
  open = true
}
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open.value = false
}
</script>
<template>
  <Button type="primary" @click="openDialog">Custom Btns Dialog</Button>
  <Dialog
    v-model:open="open"
    title="Title"
    cancel-text="Return"
    :cancel-props="{ type: 'danger', ghost: true }"
    ok-text="Submit"
    :ok-props="{ type: 'primary', ghost: true }"
    @cancel="onCancel"
    @ok="onOk"
  >
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

隐藏底部按钮

Open Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
function openDialog() {
  open = true
}
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open.value = false
}
</script>
<template>
  <Button type="primary" @click="openDialog">Open Dialog</Button>
  <Dialog v-model:open="open" title="Title" :footer="false" @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

切换全屏

Open Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
function openDialog() {
  open = true
}
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open.value = false
}
</script>
<template>
  <Button type="primary" @click="openDialog">Open Dialog</Button>
  <Dialog v-model:open="open" title="Title" switch-fullscreen @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

自定义位置

Fixed Top Number Dialog
Fixed Top Percent Dialog
Vertically Centered Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open1 = ref(false)
const open2 = ref(false)
const open3 = ref(false)
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open1.value = false
  open2.value = false
  open3.value = false
}
</script>
<template>
  <Space>
    <Button type="primary" @click="open1 = true">Fixed Top Number Dialog</Button>
    <Button type="primary" @click="open2 = true">Fixed Top Percent Dialog</Button>
    <Button type="primary" @click="open3 = true">Vertically Centered Dialog</Button>
  </Space>
  <Dialog v-model:open="open1" title="60px Top Title" :top="60" @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
  <Dialog v-model:open="open2" title="20% Top Title" top="20%" @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
  <Dialog v-model:open="open3" title="Centered Title" centered @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

动画出现位置

Transform Origin Center Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
function openDialog() {
  open = true
}
function onCancel() { // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function onOk () { // 点击确定的回调
  console.log('ok')
  open.value = false
}
</script>
<template>
  <Button type="primary" @click="openDialog">Transform Origin Center Dialog</Button>
  <Dialog v-model:open="open" title="Title" transform-origin="center" @cancel="onCancel" @ok="onOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

异步延迟关闭

Delayed Close Dialog
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const open = ref(false)
const confirmLoading = ref(false)
function openDialog() {
  open = true
}
function handleCancel() {
  // 点击蒙层或 Esc 键或右上角叉或取消按钮的回调
  console.log('cancel')
}
function handleOk() {
  // 点击确定回调
  confirmLoading.value = true // 开启加载状态
  setTimeout(() => {
    confirmLoading.value = false
    open13.value = false
    console.log('ok')
  }, 2000)
}
</script>
<template>
  <Button type="primary" @click="openDialog">Delayed Close Dialog</Button>
  <Dialog v-model:open="open" title="Title" :confirm-loading="confirmLoading" @cancel="handleCancel" @ok="handleOk">
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
    <p>Bla bla ...</p>
  </Dialog>
</template>

APIs

Dialog

参数说明类型默认值
width对话框宽度,单位 pxstring | number520
height对话框高度,单位 px,默认自适应内容高度string | number'auto'
title标题string | slotundefined
titleStyle自定义标题样式CSSProperties{}
content内容string | slotundefined
contentStyle自定义内容样式CSSProperties{}
bodyClass自定义 body 类名stringundefined
bodyStyle自定义 body 样式CSSProperties{}
scrollbarPropsScrollbar 组件属性配置,参考 Scrollbar Props,用于设置内容滚动条的样式object{}
cancelText取消按钮文字string'取消'
cancelProps取消按钮 props 配置,参考 Button Propsobject{}
okText确定按钮文字string'确定'
okType确定按钮类型'primary' | 'danger''primary'
okProps确认按钮 props 配置,优先级高于 okType,参考 Button Propsobject{}
footer是否显示底部按钮boolean | slottrue
destroyOnClose关闭时是否销毁 Dialog 里的子元素booleanfalse
switchFullscreen是否允许切换全屏,允许后右上角会出现一个切换按钮booleanfalse
centered是否水平垂直居中,否则固定高度水平居中booleanfalse
top固定高度水平居中时,距顶部高度,仅当 centered: false 时生效,单位 pxstring | number100
transformOrigin对话框动画出现的位置'mouse' | 'center''mouse'
confirmLoading确定按钮 loadingbooleanfalse
blockScroll是否在打开对话框时禁用背景滚动booleantrue
keyboard是否支持键盘 esc 关闭booleantrue
maskClosable点击蒙层是否允许关闭booleantrue
maskStyle自定义蒙层样式CSSProperties{}
open
v-model
对话框是否可见booleanfalse

Slots

名称说明类型
title自定义标题v-slot:title
default自定义内容v-slot:default
footer自定义底部内容v-slot:footer

Events

名称说明类型
cancel点击蒙层或 Esc 键或右上角叉或取消按钮的回调() => void
ok点击确定的回调() => void

Released under the MIT License.