mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-24 10:20:19 +08:00
refactor(Form): refactor with composition api
This commit is contained in:
parent
00dbf2cc50
commit
92aac941fc
@ -230,7 +230,7 @@ export default createComponent({
|
||||
|
||||
const validateWithTrigger = (trigger) => {
|
||||
if (form && props.rules) {
|
||||
const defaultTrigger = form.validateTrigger === trigger;
|
||||
const defaultTrigger = form.props.validateTrigger === trigger;
|
||||
const rules = props.rules.filter((rule) => {
|
||||
if (rule.trigger) {
|
||||
return rule.trigger === trigger;
|
||||
@ -329,7 +329,7 @@ export default createComponent({
|
||||
if (typeof props.error === 'boolean') {
|
||||
return props.error;
|
||||
}
|
||||
if (form && form.showError && state.validateFailed) {
|
||||
if (form && form.props.showError && state.validateFailed) {
|
||||
return true;
|
||||
}
|
||||
});
|
||||
@ -339,8 +339,8 @@ export default createComponent({
|
||||
return props[key];
|
||||
}
|
||||
|
||||
if (form && isDef(form[key])) {
|
||||
return form[key];
|
||||
if (form && isDef(form.props[key])) {
|
||||
return form.props[key];
|
||||
}
|
||||
};
|
||||
|
||||
@ -508,7 +508,7 @@ export default createComponent({
|
||||
};
|
||||
|
||||
const renderMessage = () => {
|
||||
if (form && form.showErrorMessage === false) {
|
||||
if (form && form.props.showErrorMessage === false) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -1,4 +1,6 @@
|
||||
import { provide, reactive } from 'vue';
|
||||
import { createNamespace } from '../utils';
|
||||
import { useExpose } from '../composition/use-expose';
|
||||
|
||||
const [createComponent, bem] = createNamespace('form');
|
||||
|
||||
@ -33,24 +35,16 @@ export default createComponent({
|
||||
|
||||
emits: ['submit', 'failed'],
|
||||
|
||||
provide() {
|
||||
return {
|
||||
[FORM_KEY]: this,
|
||||
};
|
||||
},
|
||||
setup(props, { emit, slots }) {
|
||||
const children = reactive([]);
|
||||
|
||||
data() {
|
||||
return {
|
||||
children: [],
|
||||
};
|
||||
},
|
||||
provide(FORM_KEY, { props, children });
|
||||
|
||||
methods: {
|
||||
validateSeq() {
|
||||
return new Promise((resolve, reject) => {
|
||||
const validateSeq = () =>
|
||||
new Promise((resolve, reject) => {
|
||||
const errors = [];
|
||||
|
||||
this.children
|
||||
children
|
||||
.reduce(
|
||||
(promise, field) =>
|
||||
promise.then(() => {
|
||||
@ -72,12 +66,10 @@ export default createComponent({
|
||||
}
|
||||
});
|
||||
});
|
||||
},
|
||||
|
||||
validateAll() {
|
||||
return new Promise((resolve, reject) => {
|
||||
Promise.all(this.children.map((item) => item.validate())).then(
|
||||
(errors) => {
|
||||
const validateAll = () =>
|
||||
new Promise((resolve, reject) => {
|
||||
Promise.all(children.map((item) => item.validate())).then((errors) => {
|
||||
errors = errors.filter((item) => item);
|
||||
|
||||
if (errors.length) {
|
||||
@ -85,21 +77,11 @@ export default createComponent({
|
||||
} else {
|
||||
resolve();
|
||||
}
|
||||
}
|
||||
);
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
// @exposed-api
|
||||
validate(name) {
|
||||
if (name) {
|
||||
return this.validateField(name);
|
||||
}
|
||||
return this.validateFirst ? this.validateSeq() : this.validateAll();
|
||||
},
|
||||
|
||||
validateField(name) {
|
||||
const matched = this.children.filter((item) => item.props.name === name);
|
||||
const validateField = (name) => {
|
||||
const matched = children.filter((item) => item.props.name === name);
|
||||
|
||||
if (matched.length) {
|
||||
return new Promise((resolve, reject) => {
|
||||
@ -114,65 +96,70 @@ export default createComponent({
|
||||
}
|
||||
|
||||
return Promise.reject();
|
||||
},
|
||||
};
|
||||
|
||||
// @exposed-api
|
||||
resetValidation(name) {
|
||||
this.children.forEach((item) => {
|
||||
const validate = (name) => {
|
||||
if (name) {
|
||||
return validateField(name);
|
||||
}
|
||||
return props.validateFirst ? validateSeq() : validateAll();
|
||||
};
|
||||
|
||||
const resetValidation = (name) => {
|
||||
children.forEach((item) => {
|
||||
if (!name || item.props.name === name) {
|
||||
item.resetValidation();
|
||||
}
|
||||
});
|
||||
},
|
||||
};
|
||||
|
||||
// @exposed-api
|
||||
scrollToField(name, options) {
|
||||
this.children.some((item) => {
|
||||
const scrollToField = (name, options) => {
|
||||
children.some((item) => {
|
||||
if (item.props.name === name) {
|
||||
item.root.value.scrollIntoView(options);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
});
|
||||
},
|
||||
};
|
||||
|
||||
getValues() {
|
||||
return this.children.reduce((form, field) => {
|
||||
const getValues = () =>
|
||||
children.reduce((form, field) => {
|
||||
form[field.props.name] = field.formValue;
|
||||
return form;
|
||||
}, {});
|
||||
},
|
||||
|
||||
onSubmit(event) {
|
||||
event.preventDefault();
|
||||
this.submit();
|
||||
},
|
||||
const submit = () => {
|
||||
const values = getValues();
|
||||
|
||||
// @exposed-api
|
||||
submit() {
|
||||
const values = this.getValues();
|
||||
|
||||
this.validate()
|
||||
validate()
|
||||
.then(() => {
|
||||
this.$emit('submit', values);
|
||||
emit('submit', values);
|
||||
})
|
||||
.catch((errors) => {
|
||||
this.$emit('failed', {
|
||||
values,
|
||||
errors,
|
||||
});
|
||||
emit('failed', { values, errors });
|
||||
|
||||
if (this.scrollToError) {
|
||||
this.scrollToField(errors[0].name);
|
||||
if (props.scrollToError) {
|
||||
scrollToField(errors[0].name);
|
||||
}
|
||||
});
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
render() {
|
||||
return (
|
||||
<form class={bem()} onSubmit={this.onSubmit}>
|
||||
{this.$slots.default?.()}
|
||||
const onSubmit = (event) => {
|
||||
event.preventDefault();
|
||||
submit();
|
||||
};
|
||||
|
||||
useExpose({
|
||||
submit,
|
||||
validate,
|
||||
scrollToField,
|
||||
resetValidation,
|
||||
});
|
||||
|
||||
return () => (
|
||||
<form class={bem()} onSubmit={onSubmit}>
|
||||
{slots.default?.()}
|
||||
</form>
|
||||
);
|
||||
},
|
||||
|
Loading…
x
Reference in New Issue
Block a user