vue-vben-admin/src/views/demo/comp/drawer/Drawer4.vue

57 lines
1.4 KiB
Vue
Raw Normal View History

2020-09-28 20:19:10 +08:00
<template>
<BasicDrawer v-bind="$attrs" @register="register" title="Drawer Title" width="50%">
2020-11-01 23:44:23 +08:00
<div>
2020-10-31 00:41:33 +08:00
<p class="h-20">外部传递数据: {{ receiveDrawerDataRef }}</p>
<BasicForm @register="registerForm" />
</div>
2020-09-28 20:19:10 +08:00
</BasicDrawer>
</template>
<script lang="ts">
2020-10-31 00:41:33 +08:00
import { defineComponent, nextTick } from 'vue';
2020-09-28 20:19:10 +08:00
import { BasicDrawer, useDrawerInner } from '/@/components/Drawer';
2020-10-31 00:41:33 +08:00
import { BasicForm, FormSchema, useForm } from '/@/components/Form/index';
const schemas: FormSchema[] = [
{
field: 'field1',
component: 'Input',
label: '字段1',
colProps: {
span: 12,
},
defaultValue: '111',
},
{
field: 'field2',
component: 'Input',
label: '字段2',
colProps: {
span: 12,
},
},
];
2020-09-28 20:19:10 +08:00
export default defineComponent({
2020-10-31 00:41:33 +08:00
components: { BasicDrawer, BasicForm },
2020-09-28 20:19:10 +08:00
setup() {
2020-10-31 00:41:33 +08:00
const [registerForm, { setFieldsValue }] = useForm({
labelWidth: 120,
schemas,
showActionButtonGroup: false,
actionColOptions: {
span: 24,
},
});
const [register, { receiveDrawerDataRef }] = useDrawerInner((data) => {
nextTick(() => {
// 方式1
setFieldsValue({
field2: data.data,
field1: data.info,
});
});
});
return { register, receiveDrawerDataRef, schemas, registerForm };
2020-09-28 20:19:10 +08:00
},
});
</script>