chore: form reset logic modification

This commit is contained in:
vben 2020-10-23 23:45:21 +08:00
parent e034d1bacc
commit c7cfeb5456
5 changed files with 40 additions and 25 deletions

View File

@ -8,6 +8,7 @@
### 🎫 Chores ### 🎫 Chores
- 删除代码内的可选链语法 - 删除代码内的可选链语法
- 表单重置逻辑修改
### 🐛 Bug Fixes ### 🐛 Bug Fixes

View File

@ -194,7 +194,7 @@
model: formModel, model: formModel,
field: schema.field, field: schema.field,
values: { values: {
...unerf(defaultValueRef), ...unref(defaultValueRef),
...formModel, ...formModel,
}, },
}); });
@ -271,11 +271,11 @@
const formEl = unref(formElRef); const formEl = unref(formElRef);
if (!formEl) return; if (!formEl) return;
Object.keys(formModel).forEach((key) => { Object.keys(formModel).forEach((key) => {
(formModel as any)[key] = undefined; (formModel as any)[key] = defaultValueRef.value[key];
}); });
const values = formEl.resetFields(); // const values = formEl.resetFields();
emit('reset', toRaw(formModel)); emit('reset', toRaw(formModel));
return values; // return values;
} }
/** /**

View File

@ -139,6 +139,7 @@ export default defineComponent({
} }
return rules; return rules;
} }
function renderComponent() { function renderComponent() {
const { const {
componentProps, componentProps,
@ -163,7 +164,6 @@ export default defineComponent({
} }
}, },
}; };
const Comp = componentMap.get(component); const Comp = componentMap.get(component);
const { autoSetPlaceHolder, size } = props.formProps; const { autoSetPlaceHolder, size } = props.formProps;
@ -189,9 +189,22 @@ export default defineComponent({
const bindValue = { const bindValue = {
[isCheck ? 'checked' : 'value']: (props.formModel as any)[field], [isCheck ? 'checked' : 'value']: (props.formModel as any)[field],
}; };
// TODO先兼容antd的警告后面官方修复后删除
if (component === 'Select') {
if (Reflect.has(propsData, 'options')) {
propsData.options = propsData.options.map((item: any) => {
return {
key: item.value,
...item,
};
});
}
}
if (!renderComponentContent) { if (!renderComponentContent) {
return <Comp {...propsData} {...on} {...bindValue} />; return <Comp {...propsData} {...on} {...bindValue} />;
} }
return ( return (
<Comp {...propsData} {...on} {...bindValue}> <Comp {...propsData} {...on} {...bindValue}>
{{ {{

View File

@ -8,7 +8,7 @@ import {
computed, computed,
// ref, // ref,
unref, unref,
onMounted, // onMounted,
toRaw, toRaw,
} from 'vue'; } from 'vue';
import { Tabs } from 'ant-design-vue'; import { Tabs } from 'ant-design-vue';
@ -24,7 +24,7 @@ import { tabStore } from '/@/store/modules/tab';
import { closeTab } from './useTabDropdown'; import { closeTab } from './useTabDropdown';
import router from '/@/router'; import router from '/@/router';
import { useTabs } from '/@/hooks/web/useTabs'; import { useTabs } from '/@/hooks/web/useTabs';
import { PageEnum } from '/@/enums/pageEnum'; // import { PageEnum } from '/@/enums/pageEnum';
import './index.less'; import './index.less';
export default defineComponent({ export default defineComponent({
@ -33,14 +33,17 @@ export default defineComponent({
let isAddAffix = false; let isAddAffix = false;
const go = useGo(); const go = useGo();
const { currentRoute } = useRouter(); const { currentRoute } = useRouter();
const { addTab, activeKeyRef } = useTabs(); const {
onMounted(() => { // addTab,
const route = unref(currentRoute); activeKeyRef,
addTab(unref(currentRoute).path as PageEnum, false, { } = useTabs();
query: route.query, // onMounted(() => {
params: route.params, // const route = unref(currentRoute);
}); // addTab(unref(currentRoute).path as PageEnum, false, {
}); // query: route.query,
// params: route.params,
// });
// });
// 当前激活tab // 当前激活tab
// const activeKeyRef = ref<string>(''); // const activeKeyRef = ref<string>('');
@ -64,14 +67,14 @@ export default defineComponent({
// 监听路由的话虽然可以,但是路由切换的时间会造成卡顿现象? // 监听路由的话虽然可以,但是路由切换的时间会造成卡顿现象?
// 使用useTab的addTab的话当用户手动调转需要自行调用addTab // 使用useTab的addTab的话当用户手动调转需要自行调用addTab
// tabStore.commitAddTab((unref(currentRoute) as unknown) as AppRouteRecordRaw); // tabStore.commitAddTab((unref(currentRoute) as unknown) as AppRouteRecordRaw);
// const { affix } = currentRoute.value.meta || {}; const { affix } = currentRoute.value.meta || {};
// if (affix) return; if (affix) return;
// const hasInTab = tabStore.getTabsState.some( const hasInTab = tabStore.getTabsState.some(
// (item) => item.fullPath === currentRoute.value.fullPath (item) => item.fullPath === currentRoute.value.fullPath
// ); );
// if (!hasInTab) { if (!hasInTab) {
// tabStore.commitAddTab((unref(currentRoute) as unknown) as AppRouteRecordRaw); tabStore.commitAddTab((unref(currentRoute) as unknown) as AppRouteRecordRaw);
// } }
}, },
{ {
immediate: true, immediate: true,

View File

@ -239,12 +239,10 @@ export function getFormConfig(): Partial<FormProps> {
{ {
label: '选项1', label: '选项1',
value: '1', value: '1',
key: '1',
}, },
{ {
label: '选项2', label: '选项2',
value: '2', value: '2',
key: '2',
}, },
], ],
}, },