mirror of
https://github.com/Tencent/tmagic-editor.git
synced 2025-04-05 19:41:40 +08:00
fix(form): 表单配置没有变化,初始值变化时,表单发生重绘
This commit is contained in:
parent
4f4e81f27c
commit
979336c052
@ -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,
|
||||
|
@ -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;
|
||||
|
||||
// 兼容vue2的element-ui
|
||||
tab.name = tab.paneName;
|
||||
|
||||
if (typeof config.onTabClick === 'function') {
|
||||
config.onTabClick(mForm, tab, { model, formValue: mForm?.values, prop });
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user