useForm的设计理念随笔

> 之前在研摩完 https://github.com/react-hook-form/react-hook-form 后感叹到前端的设计理念博大精深,但是一直没有整理,这两天考试周回校有空整理了一下

前有数据驱动视图的 Vue 和 React ,现在到了特殊场景又要具体分析开发的视图驱动数据的 useForm

业务情景:当一个大表单的局部字段变更时,普通 React 会直接 re-render 整个大表单导致性能耗散,最优解是尽量避免重渲染

useForm的内部可以理解为:

当用户 input 的时候 register 捕获事件,向内写入到 formValues 并更新 formState ,接着 subjects 通过观察者模式遍历广播变更,仅订阅了这些 subjects 的 hooks 会调用 useState ,从而触发最小范围的 Fiber 调度

而普通的 input 做了特判完全不会触发 re-render

复制代码
[用户输入]
    ↓ (onChange)
register -> handleChange
    ↓
更新 _formValues
    ↓
_subjects.watch.next({ name, value })  // 发布事件
    ↓
useWatch/useFormState/useController 订阅回调
    ↓
setState(...)
    ↓
React Fiber 调度(仅局部组件)

需要注意,这里的观察者模式并不像 Vue 那样去挟持属性实现响应化( Vue2 的 Object.defineProperty 和 Vue3 的 Proxy ),而是其内部自己维护了一个 subjects ,从而避免像 Vue 一样自动更新视图,遵循 React 的显式思维去广播变更,触发局部的 Fiber 调度

相关推荐
wuhen_n17 分钟前
网络请求在Vite层的代理与Mock:告别跨域和后端依赖
前端·javascript·vue.js
小彭努力中18 分钟前
193.Vue3 + OpenLayers 实战:圆孔相机模型推算卫星拍摄区域
vue.js·数码相机·vue·openlayers·geojson
用户69371750013845 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦5 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013845 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水7 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫8 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll1239 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
用头发抵命9 小时前
Vue 3 中优雅地集成 Video.js 播放器:从组件封装到功能定制
开发语言·javascript·ecmascript
蓝冰凌10 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js