我想封装一个prompt
的功能,
<template>
<a v-if="!o_visible" @click="o_handle_visible">{{o_label}}</a>
<a-modal
:title="o_title"
:ok-text="o_ok_text"
:cancel-text="o_cancel_text"
@ok="o_handle_ok"
v-model:visible="o_visible"
>
<a-input v-model:value="o_value" />
</a-modal>
</template>
<script>
import {ref, defineComponent} from "vue";
import { message } from 'ant-design-vue';
export default defineComponent({
name: 'p_prompt',
props: {
label: {
type: String
},
modal: {
type: Object
},
record: {
type: Object,
}
},
setup(props) {
let o_title = props.modal.title || "请输入谷歌验证码";
let o_ok_text = props.modal.ok_text || "提交"
let o_cancel_text = props.modal.cancel_text || "取消"
let o_visible = ref(false);
let o_value = ref("");
let o_label = props.label
let fn_reset = () => {
o_value.value = ""
}
let o_handle_visible = () => {
o_visible.value = true;
}
let o_handle_ok = async () => {
let ret = await props.modal.handle_ok(props.record, props.modal, o_value.value);
if(ret) {
message.success(props.modal.success_text || "操作成功");
o_visible.value = false;
// o_value.value = "";
fn_reset();
return;
}
}
// __export__
return {
o_title,
o_ok_text,
o_cancel_text,
o_visible,
o_handle_visible,
o_value,
o_label,
o_handle_ok,
}
// __end_export__
}
})
</script>
这是代码
但是问题是 <a v-if="!o_visible" @click="o_handle_visible">{{o_label}}</a>
这个东西我像做成 slots, 但是做成 slots,怎么触发 o_handle_visible
事件呢
我就想和 popconfirm
一样的使用体验
<a-popconfirm
title="Are you sure delete this task?"
ok-text="Yes"
cancel-text="No"
@confirm="confirm"
@cancel="cancel"
>
<a href="#">Delete</a>
</a-popconfirm>
大佬我该怎么封装呢?请指点下,我 vue3 菜鸟
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.