上一篇提到过,React 的表单管理方案有两类: 基于 redux 的全局数据管理(redux-form) 基于 react 的局部数据管理(rc-form) ?...下面给出几个用 redux-form 实现的表单示例; 1. redux-form入门 效果: ? 代码: ? 2....给表单添加校验 redux-form 支持两类表单校验: form 表单整体校验; form 表单项独立校验; 效果: ? 代码: ? 3....给表单整体赋值 redux-form 允许我们通过 initialValues 给表单整体赋值; 效果: ? 代码: ? 4. 标准化用户录入 效果: ? 代码: ? 5....API: redux-form 提供了一堆 selector,便于我们从state中获取 form 表单的各种状态数据... ?
redux是一种常用的与react框架搭配的一种数据流架构,而伴随着redux的出现,也出现了许多基于redux开源的第三方库,而redux-form就是其中之一的开源组件库,到今天我写下这篇笔记为止,...在github上获得了5580颗star和654颗的fork数,今天就写一下我的redux-form的学习笔记吧 左转redux-form的api文档地址:http://redux-form.com/6.5.0.../docs/api/ 1第一件要做的事当然是安装依赖啦,通过终端进入项目所在目录,写入npm install redux-form安装依赖(前提:已成功配置node的运行环境,并且已安装好react和redux...我的form.js如下: import React from 'react' import { Field, reduxForm } from 'redux-form' const SimpleForm...这样一个最简单的redux-form就实现啦
(注:这篇博客参考自redux-form的官方英文文档)左转http://redux-form.com/6.5.0/examples/syncValidation/ 在这篇博客里,我将用redux-form...,使redux-form同步错误提示 })(SyncValidationForm)//写入的redux-form组件 1什么是Field组件?...Field组件是redux-form组件库中的核心组件,它位于你的输入框(input)或输入框组件的外一层,将其包装起来从而使输入框能和redux的store直接连接起来。...的特殊标记,必填项 validate, // 一个验证函数,使redux-form同步验证 warn // 一个错误提示函数...,使redux-form同步错误提示 })(SyncValidationForm)//写入的redux-form组件 (这里的validate和warn采用了ES6的对象属性的简化写入写法,相当于validate
我目前接触较多的外部插件为redux-form。此处暂以redux-form更新state的方式进行一些探讨。...redux-form 当组件采用redux-form进行监听后,内部form表单里的对象都将被放入redux的state中进行管理,并由redux-form自身发起action进行更新删除等操作。...问题在于,每次表单的更新,redux-form都会发起一次action,这意味着我们在一个input框里输入一句简单的"hello world",默认情况下将会有11个state副本产生。...至于创建副本的目的是为了追溯历史操作与更改,则类似redux-form这样短时间高频率的更改state的方式,产生的大量细碎历史,或许并没有必要?...小结 就redux-form而言,在一些场景中,能明显感受到输入操作存在顿挫感。显然,当我们在选择外部插件时,需要合理考虑其对state的处理方式。
相对于 redux-form 库,我觉得 formik 库更好用一些吧。...在 Formik 官网,作者也举例了使用 redux-form 的缺陷: 表单状态本质上是短暂的和局部的,并不需要 redux 对其进行跟踪; 使用 redux 管理状态时,状态更新要派发 action...,这对于小型应用程序来说很好,但是随着 Redux 应用程序的增长,使用 Redux-Form,则输入延迟将继续增加。...redux-form 库比较大,压缩后大小为 22.5KB,而 Formik 库为 12.7KB; 关于 formik 的更多用法,可以参考官网: Formik.js[1] yup.js[2] 参考资料
为什么不使用 Redux-Form? 到现在为止,您可能会想,“为什么你不只是使用 Redux-Form?”问得好。...Redux-Form 在每次按键时都会多次调用整个顶层 Redux reducer。...对于小型应用程序来说这没问题,但如果您使用 Redux-Form,随着 Redux 应用程序的增长,输入延迟将继续增加。...Redux-Form 的大小是 22.5 kB(经过最小化和 gzip 压缩),而 Formik 的大小是 12.7 kB。
Simple Schema Joi 清晰的API,尽管这个包挺大 数据库钩子 Collections2 GraphQL GraphQL 对于小应用来说太重了 (但是内容丰富) 表单 AutoForm redux-form
什么功能内置,什么交给社区去做 (其中第3点在vue3.0支持类式写法之后就可以去掉了) react整体的思路就是函数式,所以推崇纯组件,数据不可变,单向数据流,当然需要双向的地方也可以做到,比如结合redux-form
findNodeHandle, ... } from 'react-native'; 不使用类名调用方法: findNodeHandle(ref) 0x05 redux-form问题 问题:代码如下
前有简单的 util 工具 redux-form-utils,后有庞大复杂的 redux-form,还有 rc-component 实现的一套基于 HOC 的解决方案。
其中的handleSubmit是从该表单所使用的第三方redux-form中传入的,用来处理表单提交,我们在这里不关注它,只需要知道我们需要把自己的处理函数this.submitWithErrors传给它
/Await 或装饰器;如果你刚刚开始学习 React,并不需要使用热重载和服务端渲染;如果你刚刚接触 Webpack,你就不需要分离代码和合并多个资源;如果你刚刚学习 Redux,你不需要理解使用 Redux-Form
react是整体的思路的就是函数式,所以推崇纯组件,数据不可变,单向数据流,当然需要双向的地方也可以做到,比如结合redux-form,组件的横向拆分一般是通过高阶组件。
当我们使用 Redux 时, Redux-form 看起来是一个很自然的选择,但后来他的核心开发者放弃了它; React-final-form,充满了未修复的 bug,核心开发者也放弃了; Formik
redux-devtools - Redux的DevTools,具有热重新加载,动作重放和可自定义的UI react-router-redux - 保持react-router和redux同步的绑定 redux-form
react 是整体的思路的就是函数式,所以推崇纯组件,数据不可变,单向数据流,当然需要双向的地方也可以做到,比如结合 redux-form,组件的横向拆分一般是通过高阶组件。
领取专属 10元无门槛券
手把手带您无忧上云