61 lines
1.2 KiB
Vue
61 lines
1.2 KiB
Vue
<docs>
|
||
---
|
||
order: 1
|
||
title:
|
||
zh-CN: 异步关闭
|
||
en-US: Asynchronously close
|
||
---
|
||
|
||
## zh-CN
|
||
|
||
点击确定后异步关闭对话框,例如提交表单。
|
||
|
||
## en-US
|
||
|
||
|
||
Asynchronously close a modal dialog when the OK button is pressed.
|
||
|
||
For example, you can use this pattern when you submit a form.
|
||
|
||
|
||
</docs>
|
||
|
||
<template>
|
||
<div>
|
||
<a-button type="primary" @click="showModal">Open Modal with async logic</a-button>
|
||
<a-modal v-model:open="open" title="Title" :confirm-loading="confirmLoading" @ok="handleOk">
|
||
<p>{{ modalText }}</p>
|
||
</a-modal>
|
||
</div>
|
||
</template>
|
||
<script lang="ts">
|
||
import { ref, defineComponent } from 'vue';
|
||
export default defineComponent({
|
||
setup() {
|
||
const modalText = ref<string>('Content of the modal');
|
||
const open = ref<boolean>(false);
|
||
const confirmLoading = ref<boolean>(false);
|
||
|
||
const showModal = () => {
|
||
open.value = true;
|
||
};
|
||
|
||
const handleOk = () => {
|
||
modalText.value = 'The modal will be closed after two seconds';
|
||
confirmLoading.value = true;
|
||
setTimeout(() => {
|
||
open.value = false;
|
||
confirmLoading.value = false;
|
||
}, 2000);
|
||
};
|
||
return {
|
||
modalText,
|
||
open,
|
||
confirmLoading,
|
||
showModal,
|
||
handleOk,
|
||
};
|
||
},
|
||
});
|
||
</script>
|