fix(form): 表单配置没有变化,初始值变化时,表单发生重绘

This commit is contained in:
roymondchen 2022-03-08 20:07:47 +08:00 committed by jia000
parent 4f4e81f27c
commit 979336c052
2 changed files with 37 additions and 28 deletions

View File

@ -1,6 +1,5 @@
<template>
<ElForm
v-if="initialized && Array.isArray(config)"
<el-form
class="m-form"
ref="elForm"
:model="values"
@ -10,25 +9,26 @@
:inline="inline"
:label-position="labelPosition"
>
<MContainer
v-for="(item, index) in config"
:key="item[keyProp] ?? index"
:config="item"
:model="values"
:label-width="item.labelWidth || labelWidth"
:step-active="stepActive"
:size="size"
@change="changeHandler"
></MContainer>
</ElForm>
<template v-if="initialized && Array.isArray(config)">
<m-form-container
v-for="(item, index) in config"
:key="item[keyProp] ?? index"
:config="item"
:model="values"
:label-width="item.labelWidth || labelWidth"
:step-active="stepActive"
:size="size"
@change="changeHandler"
></m-form-container>
</template>
</el-form>
</template>
<script lang="ts">
import { defineComponent, PropType, provide, reactive, ref, watchEffect } from 'vue';
import { defineComponent, PropType, provide, reactive, ref, toRaw, watch } from 'vue';
import { ElForm } from 'element-plus';
import { cloneDeep } from 'lodash-es';
import { cloneDeep, isEqual } from 'lodash-es';
import MContainer from './containers/Container.vue';
import { getConfig } from './utils/config';
import { initValue } from './utils/form';
import { FormConfig, FormState, FormValue } from './schema';
@ -45,8 +45,6 @@ export interface FieldErrorList {
export default defineComponent({
name: 'm-form',
components: { ElForm, MContainer },
props: {
//
initValues: {
@ -140,16 +138,23 @@ export default defineComponent({
provide('mForm', formState);
watchEffect(() => {
initialized.value = false;
initValue(formState, {
initValues: props.initValues,
config: props.config,
}).then((value) => {
values.value = value;
initialized.value = true;
});
});
watch(
[() => props.config, () => props.initValues],
([config], [preConfig]) => {
if (!isEqual(toRaw(config), toRaw(preConfig))) {
initialized.value = false;
}
initValue(formState, {
initValues: props.initValues,
config: props.config,
}).then((value) => {
values.value = value;
initialized.value = true;
});
},
{ immediate: true },
);
return {
initialized,

View File

@ -54,6 +54,10 @@ const getActive = (mForm: FormState | undefined, props: any, activeTabName: stri
const tabClickHandler = (mForm: FormState | undefined, tab: any, props: any) => {
const { config, model, prop } = props;
// vue2element-ui
tab.name = tab.paneName;
if (typeof config.onTabClick === 'function') {
config.onTabClick(mForm, tab, { model, formValue: mForm?.values, prop });
}