formik 的使用

礼记有言:独学而无友,则孤陋而寡闻
让我们一起了解更多便捷方法,缩短开发时间去摸鱼,嘿嘿。

框架:react
在写表单的时候,我不太喜欢把验证写的很繁琐,这里讲介绍,验证表单的非常好用的验证库:Formik + Zod 和 Formik + Yup 。
其实,react-hook-form +Zod 的 周下载量也超级高,不过我还是更喜欢Formik,这里react-hook-form 就不做介绍了,留给by搜索引擎需要form表单的公主or 王子 一个选择,礼记有言:教学相长。如果你有更好的方法,也可以分享给我哟,嘿嘿。

formik 的使用

radio请添加图片描述

import React from 'react';
import { useFormik } from 'formik';export function FormikStudyRadio() {const formik = useFormik({initialValues: {gender: '',},onSubmit: (values) => {alert(JSON.stringify(values, null, 2));},validate: (values) => {console.log(values.gender, '-')if (!values.gender) {return { gender: "请选择你的性别" };}console.log(values.gender);},});return (<form onSubmit={formik.handleSubmit} className='flex items-center gap-2'><label><inputtype="radio"name="gender"value="male"checked={formik.values.gender === 'male'}onChange={formik.handleChange}/></label><div><label><inputtype="radio"name="gender"value="female"checked={formik.values.gender === 'female'}onChange={formik.handleChange}/></label></div>{formik.touched.gender && formik.errors.gender ? (<div className='text-red-400'>{formik.errors.gender}</div>) : null}<button type="submit" className="p-2 border border-gray-400 ml-4 rounded-[8px]">Submit</button></form>);
}

checkbox

请添加图片描述

import React from "react";
import { useFormik } from "formik";export const FormikStudy = () => {const formik = useFormik({initialValues: {friends: [],},onSubmit: (values) => {alert(JSON.stringify(values, null, 2));},validate: (values) => {if (!values.friends.length) {return { friends: "Required!" };}console.log(values.friends);},});return (<div ><form onSubmit={formik.handleSubmit} className="[&>label]:text-xl [&>label]:mr-4 [&>label>input]:mr-1 text-left"><label><inputname="friends"type="checkbox"onChange={formik.handleChange}value="carrot"/>carrot</label><label><inputname="friends"type="checkbox"onChange={formik.handleChange}value="monet"/>monet</label><button className="p-2 border border-gray-400 ml-4 rounded-[8px]" type="submit">Submit</button></form><div className="text-red-600 text-sm text-left">{formik.errors.friends}</div></div>);
};

普通文本

Formik + Zod
请添加图片描述

import React from "react";
import { useFormik } from "formik";
import { z } from "zod";
import { withZodSchema } from "formik-validator-zod";const validationSchema = z.object({name: z.string().min(8, { message: "Must be 8 or more characters long" }),desc: z.string().nonempty(),email: z.string().email({ message: "Invalid email address" }),
})const valuesType = ["text", "text", 'email']type ValuesState = {name: string,desc: string,email: string
}
const initialValues: ValuesState = {name: '',desc: '',email: ''
}
export const FormikStudy2 = () => {const formik = useFormik({initialValues,validate: withZodSchema(validationSchema),onSubmit: (values) => {alert(JSON.stringify(values, null, 2));},});const errors: any = formik.errors.valueOf()return (<div><form onSubmit={formik.handleSubmit} className="flex flex-col gap-2 m-2">{Object.keys(initialValues).map((key, index) => <div key={index} className="flex flex-col items-start"><div><label htmlFor={`${key}`}>{key}:</label><inputclassName="border border-gray-400 p-1 ml-1 rounded-lg"id={`${key}`}// name={`${key}`}type={`${valuesType[index]}`}// onChange={formik.handleChange}// value={formik.values[`${key}`]}{...formik.getFieldProps(`${key}`)}/></div><div className="text-red-600 text-sm text-left">{formik.errors && formik.errors.hasOwnProperty(key) && errors[`${key}`]}</div></div>)}<button type="submit" className="w-[100px] p-2 border border-gray-400  rounded-[8px]">Submit</button></form></div>);
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/66618.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM实战—OOM的生产案例

1.每秒仅上百请求的系统为何会OOM(RPC超时时间设置过长导致QPS翻几倍) (1)案例背景 在这个案例中&#xff0c;一个每秒仅仅只有100请求的系统却因频繁OOM而崩溃。这个OOM问题会涉及&#xff1a;Tomcat底层工作原理、Tomcat内核参数的设置、服务请求超时时间。 (2)系统发生OOM的…

数字IC设计高频面试题

在数字IC设计领域&#xff0c;面试是评估候选人技术能力和问题解决能力的重要环节。数字IC设计的复杂性和要求在不断提高。面试官通常会提出一系列面试题&#xff0c;以考察应聘者在数字设计、验证、时钟管理、功耗优化等方面的专业知识和实践经验。 这些题目不仅涉及理论知识…

OSI模型的网络层中产生拥塞的主要原因?

&#xff08; 1 &#xff09;缓冲区容量有限&#xff1b;&#xff08; 1.5 分&#xff09; &#xff08; 2 &#xff09;传输线路的带宽有限&#xff1b;&#xff08; 1.5 分&#xff09; &#xff08; 3 &#xff09;网络结点的处理能力有限&#xff1b;&#xff08; 1 分…

用OpenCV实现UVC视频分屏

分屏 OpencvUVC代码验证后话 用OpenCV实现UVC摄像头的视频分屏。 Opencv opencv里有很多视频图像的处理功能。 UVC Usb 视频类&#xff0c;免驱动的。视频流格式有MJPG和YUY2。MJPG是RGB三色通道的。要对三通道进行分屏显示。 代码 import cv2 import numpy as np video …

备战蓝桥杯 链表详解

链表概念 上一次我们用顺序存储实现了线性表&#xff0c;这次我们用链式存储结构实现的线性表就叫链表 链表每个节点包含数据本身和下一个节点和上一个节点的地址 链表的分类 单链表 双链表 带头链表 不带头链表 循环链表等等 我们竞赛一般都用的是带头链表 双向链表的…

DeepSeek:性能强劲的开源模型

deepseek 全新系列模型 DeepSeek-V3 首个版本上线并同步开源。登录官网 chat.deepseek.com 即可与最新版 V3 模型对话。 性能对齐海外领军闭源模型​ DeepSeek-V3 为自研 MoE 模型&#xff0c;671B 参数&#xff0c;激活 37B&#xff0c;在 14.8T token 上进行了预训练。 论…

Redis Zset有序集合

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 Redis Zset有序集合 收录于专栏[redis] 本专栏旨在分享学习Redis的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 概述 普通命令 ZAD…

Python中的可变对象与不可变对象;Python中的六大标准数据类型哪些属于可变对象,哪些属于不可变对象

Python中的可变对象与不可变对象&#xff1b;Python中的六大标准数据类型哪些属于可变对象&#xff0c;哪些属于不可变对象 Python中的可变对象与不可变对象一、Python的六大标准数据类型1. 数字类型 (Number)2. 字符串 (String)3. 列表 (List)4. 元组 (Tuple)5. 集合 (Set)6. …

Unity 2d描边基于SpriteRender,高性能的描边解决方案

目标 以Unity默认渲染管线为例&#xff0c;打造不需要图片内边距&#xff0c;描边平滑&#xff0c;高性能的描边解决方案 前言 在2d游戏中经常需要给2d对象添加描边&#xff0c;来突出强调2d对象 当你去网上查找2d描边shader&#xff0c;移植到项目里面&#xff0c;大概率会…

Oracle OCP考试常见问题之线上考试流程

首先要注意的是&#xff1a;虽然Oracle官方在国际上取消了获得OCP认证需要培训记录的要求&#xff0c;但在中国区&#xff0c;考生仍然需要参加Oracle的官方或者其合作伙伴组织的培训&#xff0c;并且由Oracle授权培训中心向Oracle提交学员培训记录。考生只有在完成培训并通过考…

基于海思soc的智能产品开发(camera sensor的两种接口)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 对于嵌入式开发设备来说&#xff0c;除了图像显示&#xff0c;图像输入也是很重要的一部分。说到图像输入&#xff0c;就不得不提到camera。目前ca…

Redis 笔记(二)-Redis 安装及测试

一、什么是 Redis 中文网站 Redis&#xff08;Remote Dictionary Server )&#xff0c;即远程字典服务&#xff0c;是一个开源的使用 ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value&#xff0c;并提供多种语言的 API。 Redis 开源&#xff0c;遵循 BSD 基…

H2数据库在单元测试中的应用

H2数据库特征 用比较简洁的话来介绍h2数据库&#xff0c;就是一款轻量级的内存数据库&#xff0c;支持标准的SQL语法和JDBC API&#xff0c;工业领域中&#xff0c;一般会使用h2来进行单元测试。 这里贴一下h2数据库的主要特征 Very fast database engineOpen sourceWritten…

通俗易懂之线性回归时序预测PyTorch实践

线性回归&#xff08;Linear Regression&#xff09;是机器学习中最基本且广泛应用的算法之一。它不仅作为入门学习的经典案例&#xff0c;也是许多复杂模型的基础。本文将全面介绍线性回归的原理、应用&#xff0c;并通过一段PyTorch代码进行实践演示&#xff0c;帮助读者深入…

MATLAB深度学习实战文字识别

文章目录 前言视频演示效果1.DB文字定位环境配置安装教程与资源说明1.1 DB概述1.2 DB算法原理1.2.1 整体框架1.2.2 特征提取网络Resnet1.2.3 自适应阈值1.2.4 文字区域标注生成1.2.5 DB文字定位模型训练 2.CRNN文字识别2.1 CRNN概述2.2 CRNN原理2.2.1 CRNN网络架构实现2.2.2 CN…

和为0的四元组-蛮力枚举(C语言实现)

目录 一、问题描述 二、蛮力枚举思路 1.初始化&#xff1a; 2.遍历所有可能的四元组&#xff1a; 3.检查和&#xff1a; 4.避免重复&#xff1a; 5.更新计数器&#xff1a; 三、代码实现 四、运行结果 五、 算法复杂度分析 一、问题描述 给定一个整数数组 nums&…

SpringBoot日常:集成Kafka

文章目录 1、pom.xml文件2、application.yml3、生产者配置类4、消费者配置类5、消息订阅6、生产者发送消息7、测试发送消息 本章内容主要介绍如何在springboot项目对kafka进行整合&#xff0c;最终能达到的效果就是能够在项目中通过配置相关的kafka配置&#xff0c;就能进行消息…

【实用技能】如何使用 .NET C# 中的 Azure Key Vault 中的 PFX 证书对 PDF 文档进行签名

TX Text Control 是一款功能类似于 MS Word 的文字处理控件&#xff0c;包括文档创建、编辑、打印、邮件合并、格式转换、拆分合并、导入导出、批量生成等功能。广泛应用于企业文档管理&#xff0c;网站内容发布&#xff0c;电子病历中病案模板创建、病历书写、修改历史、连续打…

33.3K 的Freqtrade:开启加密货币自动化交易之旅

“ 如何更高效、智能地进行交易成为众多投资者关注的焦点。” Freqtrade 是一款用 Python 编写的免费开源加密货币交易机器人。它就像一位不知疲倦的智能交易助手&#xff0c;能够连接到众多主流加密货币交易所&#xff0c;如 Binance、Bitmart、Bybit 等&#xff08;支…

Mac M2基于MySQL 8.4.3搭建(伪)主从集群

前置准备工作 安装MySQL 8.4.3 参考博主之前的文档&#xff0c;在本地Mac安装好MySQL&#xff1a;Mac M2 Pro安装MySQL 8.4.3安装目录&#xff1a;/usr/local/mysql&#xff0c;安装好的MySQL都处于运行状态&#xff0c;需要先停止MySQL服务最快的方式&#xff1a;系统设置 …