您可能会发现需要链接两个字段;当一个字段的值更改时,另一个字段需要重新验证。一个常见的用例是您同时拥有 password 和 confirm_password 字段,您希望当 password 的值不匹配时,confirm_password 字段报错;无论哪个字段触发了值更改。
想象以下用户流程
在此示例中,表单仍然会存在错误,因为“确认密码”字段的验证尚未重新运行以标记为已接受。
为了解决这个问题,我们需要确保在密码字段更新时重新运行“确认密码”验证。为此,您可以向 confirm_password 字段添加 onChangeListenTo 属性。
<script setup lang="ts">
import { useForm } from '@tanstack/vue-form'
const form = useForm({
defaultValues: {
password: '',
confirm_password: '',
},
// ...
})
</script>
<template>
<div>
<form @submit.prevent.stop="form.handleSubmit">
<div>
<form.Field name="password">
<template v-slot="{ field }">
<div>Password:</div>
<input
:value="field.state.value"
@input="
(e) => field.handleChange((e.target as HTMLInputElement).value)
"
/>
</template>
</form.Field>
<form.Field
name="confirm_password"
:validators="{
onChangeListenTo: ['password'],
onChange: ({ value, fieldApi }) => {
if (value !== fieldApi.form.getFieldValue('password')) {
return 'Passwords do not match'
}
return undefined
},
}"
>
<template v-slot="{ field }">
<div>Confirm Password:</div>
<input
:value="field.state.value"
@input="
(e) => field.handleChange((e.target as HTMLInputElement).value)
"
/>
<div v-for="(err, index) in field.state.meta.errors" :key="index">
{{ err }}
</div>
</template>
</form.Field>
</div>
<button type="submit">Submit</button>
</form>
</div>
</template>
<script setup lang="ts">
import { useForm } from '@tanstack/vue-form'
const form = useForm({
defaultValues: {
password: '',
confirm_password: '',
},
// ...
})
</script>
<template>
<div>
<form @submit.prevent.stop="form.handleSubmit">
<div>
<form.Field name="password">
<template v-slot="{ field }">
<div>Password:</div>
<input
:value="field.state.value"
@input="
(e) => field.handleChange((e.target as HTMLInputElement).value)
"
/>
</template>
</form.Field>
<form.Field
name="confirm_password"
:validators="{
onChangeListenTo: ['password'],
onChange: ({ value, fieldApi }) => {
if (value !== fieldApi.form.getFieldValue('password')) {
return 'Passwords do not match'
}
return undefined
},
}"
>
<template v-slot="{ field }">
<div>Confirm Password:</div>
<input
:value="field.state.value"
@input="
(e) => field.handleChange((e.target as HTMLInputElement).value)
"
/>
<div v-for="(err, index) in field.state.meta.errors" :key="index">
{{ err }}
</div>
</template>
</form.Field>
</div>
<button type="submit">Submit</button>
</form>
</div>
</template>
这同样适用于 onBlurListenTo 属性,它将在字段失去焦点时重新运行验证。
您的每周 JavaScript 新闻速递。每周一免费发送给超过 10 万名开发者。