仿照 NiceModal 实现的,vue2 版 NiceDialog。
灵感来源 NiceModalReact。
对@xekin这篇文章Vue2 Dialog 弹窗函数式调用最佳实践的实现。
代码借鉴了Vue2 Dialog 弹窗函数式调用最佳实践。 功能没NiceModalReact那么强大,只是用法相似。
父组件使用
import NiceDialog from 'nice-dialog-vue2';
import Dialog from './dialog.vue';
const dialogInstance = NiceDialog.create(Dialog);
export default {
methods: {
onOpen() {
dialogInstance.open(undefined, this);
}
}
};
子组件(dialog)
<template>
<el-dialog title="提示" :visible="visible" @close="onClose">
这是一段信息
<template #footer >
<el-button @click="onClose">取 消</el-button>
<template-button type="primary" @click="onClose">确 定</el-button>
</template>
</el-dialog>
</template>
<script>
export default {
data() {
return {
visible: false
};
},
methods: {
onClose() {
this.visible = false;
},
}
};
</script>
父组件使用
import NiceDialog from 'nice-dialog-vue2';
import Dialog from './dialog.vue';
const dialogInstance = NiceDialog.create(Dialog);
export default {
methods: {
onOpen() {
dialogInstance.open({ title: '明天', content: '你好' }, this);
}
}
};
子组件(dialog)
<template>
<el-dialog :title="title" :visible="visible" @close="onClose">
{{ content }}
<template #footer>
<el-button @click="onClose">取 消</el-button>
<template-button type="primary" @click="onClose">确 定</el-button>
</template>
</el-dialog>
</template>
<script>
export default {
props: {
title: {
type: String,
default: ''
},
content: {
type: String,
default: ''
}
},
data() {
return {
visible: false
};
},
methods: {
onClose() {
this.visible = false;
},
}
};
</script>
create 加上 destroy 参数。
父组件使用
import NiceDialog from 'nice-dialog-vue2';
import Dialog from './dialog.vue';
const dialogInstance = NiceDialog.create(Dialog, { destroy: false });
export default {
methods: {
onOpen() {
dialogInstance.open({ title: '明天', content: '你好' }, this);
}
}
};
const [Test1, Test2, Test3, Test4] = NiceDialog.create([Test, Test, Test, Test]);
example/src/components/Promise/index.vue
async onOpen() {
await PromiseDialog.open({ title: '明天', content: '你好' }, this)
this.$message.success('打开成功');
}
这个是个人信息的页面,其中index.vue
里有个表格。
表格“操作”列中,使用三个按钮触发,弹出不同弹窗;如下。
- Project.vue [项目信息]
- Company.vue [机构信息]
- Region.vue [地址信息]
dialog/index.js
import NiceDialog from 'nice-dialog-vue2';
import Project from './Project.vue';
import Region from './Region.vue';
import Company from './Company.vue';
export const [CompanyDialog, ProjectDialog, RegionDialog] = NiceDialog.create(
[Company, Project, Region],
{ destroy: false }
);
index.vue
import { CompanyDialog, ProjectDialog, RegionDialog } from './dialogs';
export default {
methods: {
onOpenCompany() {
CompanyDialog.open({ title: '公司信息' }, this);
},
onOpenProject() {
ProjectDialog.open({ title: '项目信息' }, this);
},
onOpenRegionDialog() {
RegionDialog.open({ title: '地址信息' }, this);
}
}
};
</script>
代码在/example/src/components/Reality/PersonalInfo
。