fix: 修复表单验证 (#2620)

1.优化验证
2.修复自定义组件验证出错的问题
This commit is contained in:
lzdjack 2023-03-14 17:06:10 +08:00 committed by GitHub
parent d7f5dfeb9f
commit 3de5b53bcd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 44 additions and 11 deletions

View File

@ -64,7 +64,6 @@
import { basicProps } from './props'; import { basicProps } from './props';
import { useDesign } from '/@/hooks/web/useDesign'; import { useDesign } from '/@/hooks/web/useDesign';
import { cloneDeep } from 'lodash-es'; import { cloneDeep } from 'lodash-es';
import { isFunction, isArray } from '/@/utils/is';
export default defineComponent({ export default defineComponent({
name: 'BasicForm', name: 'BasicForm',
@ -245,14 +244,11 @@
function setFormModel(key: string, value: any, schema: FormSchema) { function setFormModel(key: string, value: any, schema: FormSchema) {
formModel[key] = value; formModel[key] = value;
const { validateTrigger } = unref(getBindValue); emit('field-value-change', key, value);
if (isFunction(schema.dynamicRules) || isArray(schema.rules)) { // TODO autoLink=false
return; if (schema && schema.itemProps && !schema.itemProps.autoLink) {
}
if (!validateTrigger || validateTrigger === 'change') {
validateFields([key]).catch((_) => {}); validateFields([key]).catch((_) => {});
} }
emit('field-value-change', key, value);
} }
function handleEnterPress(e: KeyboardEvent) { function handleEnterPress(e: KeyboardEvent) {

View File

@ -9,7 +9,11 @@
import { BasicHelp } from '/@/components/Basic'; import { BasicHelp } from '/@/components/Basic';
import { isBoolean, isFunction, isNull } from '/@/utils/is'; import { isBoolean, isFunction, isNull } from '/@/utils/is';
import { getSlot } from '/@/utils/helper/tsxHelper'; import { getSlot } from '/@/utils/helper/tsxHelper';
import { createPlaceholderMessage, setComponentRuleType } from '../helper'; import {
createPlaceholderMessage,
NO_AUTO_LINK_COMPONENTS,
setComponentRuleType,
} from '../helper';
import { cloneDeep, upperFirst } from 'lodash-es'; import { cloneDeep, upperFirst } from 'lodash-es';
import { useItemLabelWidth } from '../hooks/useLabelWidth'; import { useItemLabelWidth } from '../hooks/useLabelWidth';
import { useI18n } from '/@/hooks/web/useI18n'; import { useI18n } from '/@/hooks/web/useI18n';
@ -347,6 +351,15 @@
const showSuffix = !!suffix; const showSuffix = !!suffix;
const getSuffix = isFunction(suffix) ? suffix(unref(getValues)) : suffix; const getSuffix = isFunction(suffix) ? suffix(unref(getValues)) : suffix;
// TODO autoLink=false
if (NO_AUTO_LINK_COMPONENTS.includes(component)) {
props.schema &&
(props.schema.itemProps! = {
autoLink: false,
...props.schema.itemProps,
});
}
return ( return (
<Form.Item <Form.Item
name={field} name={field}

View File

@ -72,3 +72,16 @@ export function handleInputNumberValue(component?: ComponentType, val?: any) {
export const dateItemType = genType(); export const dateItemType = genType();
export const defaultValueComponents = ['Input', 'InputPassword', 'InputSearch', 'InputTextArea']; export const defaultValueComponents = ['Input', 'InputPassword', 'InputSearch', 'InputTextArea'];
// TODO 自定义组件封装会出现验证问题,因此这里目前改成手动触发验证
export const NO_AUTO_LINK_COMPONENTS: ComponentType[] = [
'Upload',
'ApiTransfer',
'ApiTree',
'ApiSelect',
'ApiTreeSelect',
'ApiRadioGroup',
'ApiCascader',
'AutoComplete',
'RadioButtonGroup',
];

View File

@ -41,9 +41,7 @@ export function useRuleFormItem<T extends Recordable>(
if (isEqual(value, defaultState.value)) return; if (isEqual(value, defaultState.value)) return;
innerState.value = value as T[keyof T]; innerState.value = value as T[keyof T];
setTimeout(() => { emit?.(changeEvent, value, ...(toRaw(unref(emitData)) || []));
emit?.(changeEvent, value, ...(toRaw(unref(emitData)) || []));
});
}, },
}); });

View File

@ -68,6 +68,7 @@
import { Select } from 'ant-design-vue'; import { Select } from 'ant-design-vue';
import { cloneDeep } from 'lodash-es'; import { cloneDeep } from 'lodash-es';
import { areaRecord } from '/@/api/demo/cascader'; import { areaRecord } from '/@/api/demo/cascader';
import { uploadApi } from '/@/api/sys/upload';
const valueSelectA = ref<string[]>([]); const valueSelectA = ref<string[]>([]);
const valueSelectB = ref<string[]>([]); const valueSelectB = ref<string[]>([]);
@ -189,6 +190,18 @@
}, },
suffix: '天', suffix: '天',
}, },
{
field: 'fieldsc',
component: 'Upload',
label: '上传',
colProps: {
span: 8,
},
rules: [{ required: true, message: '请选择上传文件' }],
componentProps: {
api: uploadApi,
},
},
{ {
field: 'field3', field: 'field3',
component: 'DatePicker', component: 'DatePicker',