react中的formik如何使用

news/2024/11/17 10:49:45/

介绍:

Formik 是一个用于处理表单状态和验证的 React 库。它提供了一种简化和统一的方式来处理复杂的表单逻辑,包括表单值的管理、表单验证、表单提交和错误处理等。

使用

  1. 安装 Formik 和 Yup(用于表单验证):
    // bashnpm install formik yup
  2. 导入所需的模块:
     
    // jsximport React from 'react';
    import { Formik, Form, Field, ErrorMessage } from 'formik';
    import * as Yup from 'yup';
  3. 创建表单组件:
    jsxfunction MyForm() {// 定义初始表单值const initialValues = {name: '',email: '',password: '',};// 定义表单验证规则const validationSchema = Yup.object({name: Yup.string().required('Name is required'),email: Yup.string().email('Invalid email address').required('Email is required'),password: Yup.string().min(6, 'Password must be at least 6 characters').required('Password is required'),});// 处理表单提交const handleSubmit = (values, { setSubmitting }) => {setTimeout(() => {alert(JSON.stringify(values, null, 2));setSubmitting(false);}, 400);};return (<FormikinitialValues={initialValues}validationSchema={validationSchema}onSubmit={handleSubmit}><Form><div><label htmlFor="name">Name</label><Field type="text" id="name" name="name" /><ErrorMessage name="name" component="div" className="error" /></div><div><label htmlFor="email">Email</label><Field type="email" id="email" name="email" /><ErrorMessage name="email" component="div" className="error" /></div><div><label htmlFor="password">Password</label><Field type="password" id="password" name="password" /><ErrorMessage name="password" component="div" className="error" /></div><button type="submit">Submit</button></Form></Formik>);
    }
  4. 渲染表单组件:
    // jsxfunction App() {return (<div className="App"><MyForm /></div>);
    }


    通过上述步骤,你就可以在 React 应用中使用 Formik 来管理表单状态和验证。Formik 提供了一套简单但功能强大的 API,使得表单处理变得更加简单和一致,并提供了对表单验证的支持。你可以根据具体需求自定义表单组件和验证规则,以实现灵活且可靠的表单处理。

http://www.ppmy.cn/news/1018088.html

相关文章

【Kubrenetes】Pod基础概念

目录 在Kubrenetes集群中Pod有如下两种使用方式&#xff1a; pause容器使得Pod中的所有容器可以共享两种资源&#xff1a;网络和存储。 ●网络&#xff1a; ●存储&#xff1a; 总结&#xff1a; kubernetes中的pause容器主要为每个容器提供以下功能&#xff1a; Kubern…

篇二十三:设计模式的综合实例:构建完整项目

篇二十三&#xff1a;"设计模式的综合实例&#xff1a;构建完整项目" 开始本篇文章之前先推荐一个好用的学习工具&#xff0c;AIRIght&#xff0c;借助于AI助手工具&#xff0c;学习事半功倍。欢迎访问&#xff1a;http://airight.fun/。 另外有2本不错的关于设计模…

Go学习第八天

签名 func (a *Account) Sign(message []byte) ([]byte, error) {hash : crypto.Keccak256Hash(message)signature, err : crypto.Sign(hash.Bytes(), a.privateKeyECDSA)if err ! nil {log.Fatal(err)}signMsg : []byte(hexutil.Encode(signature))return signMsg, err }验签…

hhc.exe本地制作、手动生成chm电子书

准备几个文件 test.hhp(配置文件)test.hhc(目录文件)test.html(点击节点右侧显示的内容)hhc.exe去这里下载,链接在文章最后test.hhp [OPTIONS] Compiled file=test.chm Contents file=test.hhc Index file=test.hhc Title=chm中文title标题 Language=0x804 中文(中国) …

C/C++/QT/Python/MATLAB获取文件行数的示例

1. C获取文件行数 #include <stdio.h>int main() {FILE *file fopen("path/to/your/file.txt", "r");if (file NULL) {printf("Failed to open the file!\n");return 0;}int lineCount 0;char ch;while ((ch fgetc(file)) ! EOF) {if…

积累常见的有针对性的python面试题---python面试题001

1.考点列表的.remove方法的参数是传入的对应的元素的值,而不是下标 然后再看remove这里,注意这个是,删除写的那个值,比如这里写3,就是删除3, 而不是下标. remove不是下标删除,而是内容删除. 2.元组操作,元组不支持修改,某个下标的内容 可以问他如何修改元组的某个元素 3.…

LeetCode练习习题集【4月 - 7 月】

LEETCODE习题集【4月-7月总结】 简单 数组部分 1.重复数 题目&#xff1a; 在一个长度u为 n 的数组 nums 里的所有数字都在 0&#xff5e;n-1 的范围内。数组中某些数字是重复的&#xff0c;但不知道有几个数字重复了&#xff0c;也不知道每个数字重复了几次。请找出数组中…