您可能有多种提交行为,例如返回到另一个页面或停留在表单中。您可以通过指定 onSubmitMeta 属性来完成此操作。这些元数据将传递给 onSubmit 函数。
注意:如果 form.handleSubmit() 在没有元数据的情况下调用,它将使用提供的默认值。
import { useForm } from '@tanstack/react-form'
type FormMeta = {
submitAction: 'continue' | 'backToMenu' | null
}
// Metadata is not required to call form.handleSubmit().
// Specify what values to use as default if no meta is passed
const defaultMeta: FormMeta = {
submitAction: null,
}
function App() {
const form = useForm({
defaultValues: {
data: '',
},
// Define what meta values to expect on submission
onSubmitMeta: defaultMeta,
onSubmit: async ({ value, meta }) => {
// Do something with the values passed via handleSubmit
console.log(`Selected action - ${meta.submitAction}`, value)
},
})
return (
<form
onSubmit={(e) => {
e.preventDefault()
e.stopPropagation()
}}
>
{/* ... */}
<button
type="submit"
// Overwrites the default specified in onSubmitMeta
onClick={() => form.handleSubmit({ submitAction: 'continue' })}
>
Submit and continue
</button>
<button
type="submit"
onClick={() => form.handleSubmit({ submitAction: 'backToMenu' })}
>
Submit and back to menu
</button>
</form>
)
}
import { useForm } from '@tanstack/react-form'
type FormMeta = {
submitAction: 'continue' | 'backToMenu' | null
}
// Metadata is not required to call form.handleSubmit().
// Specify what values to use as default if no meta is passed
const defaultMeta: FormMeta = {
submitAction: null,
}
function App() {
const form = useForm({
defaultValues: {
data: '',
},
// Define what meta values to expect on submission
onSubmitMeta: defaultMeta,
onSubmit: async ({ value, meta }) => {
// Do something with the values passed via handleSubmit
console.log(`Selected action - ${meta.submitAction}`, value)
},
})
return (
<form
onSubmit={(e) => {
e.preventDefault()
e.stopPropagation()
}}
>
{/* ... */}
<button
type="submit"
// Overwrites the default specified in onSubmitMeta
onClick={() => form.handleSubmit({ submitAction: 'continue' })}
>
Submit and continue
</button>
<button
type="submit"
onClick={() => form.handleSubmit({ submitAction: 'backToMenu' })}
>
Submit and back to menu
</button>
</form>
)
}
虽然 Tanstack Form 为验证提供了 标准模式支持,但它不会保留模式的输出数据。
传递给 onSubmit 函数的值将始终是输入数据。要接收标准模式的输出数据,请在 onSubmit 函数中解析它。
const schema = z.object({
age: z.string().transform((age) => Number(age)),
})
// Tanstack Form uses the input type of Standard Schemas
const defaultValues: z.input<typeof schema> = {
age: '13',
}
const form = useForm({
defaultValues,
validators: {
onChange: schema,
},
onSubmit: ({ value }) => {
const inputAge: string = value.age
// Pass it through the schema to get the transformed value
const result = schema.parse(value)
const outputAge: number = result.age
},
})
const schema = z.object({
age: z.string().transform((age) => Number(age)),
})
// Tanstack Form uses the input type of Standard Schemas
const defaultValues: z.input<typeof schema> = {
age: '13',
}
const form = useForm({
defaultValues,
validators: {
onChange: schema,
},
onSubmit: ({ value }) => {
const inputAge: string = value.age
// Pass it through the schema to get the transformed value
const result = schema.parse(value)
const outputAge: number = result.age
},
})
您的每周 JavaScript 资讯。每周一免费发送给超过 10 万开发者。