網(wǎng)站首頁 編程語言 正文
引言
今天將之前的內(nèi)容做個系統(tǒng)整理,結(jié)合 React Form 案例, 來了解下為何React推薦單向數(shù)據(jù)流,如果采用雙向管理,可能的問題 (關于React Form案例,可參考相關文章 - 學習React的特征(二) - React Form
集中狀態(tài)管理
首先來看之前的React Form, 若采用單向數(shù)據(jù)流
import * as React from 'react'; const Useremail = props => <input type="email" {...props} /> const Userpassword = props => <input type="password" {...props} /> const SubmitButton = props => <button type="submit" {...props} /> const LoginForm = () => { // LoginForm狀態(tài)變化 => Useremail/Userpassword組件 const [email, setEmail] = React.useState(''); const [password, setPassword] = React.useState(''); const handleEmail = (e) => { setEmail(e.target.value); }; const handlePassword = (e) => { setPassword(e.target.value); }; const handleSubmit = (e) => { e.preventDefault(); alert(email + ' ' + password); }; return ( <form onSubmit={handleSubmit}> <div> <label htmlFor="email">Email</label> <Useremail id="email" type="text" value={email} onChange={handleEmail} /> </div> <div> <label htmlFor="password">Password</label> <Userpassword id="password" type="password" value={password} onChange={handlePassword} /> </div> <SubmitButton type="submit">Submit</SubmitButton> </form> ); }; export { LoginForm };
可以看到, 每次Useremail
or Password
輸入發(fā)生改變時,LoginForm
中的email
與password
狀態(tài)動態(tài)產(chǎn)生改變
雙向數(shù)據(jù)流
import * as React from 'react'; // Useremail/Userpassword組件狀態(tài)變化 => LoginForm父組件 const Useremail = ({updateUseremail, ...props}) => <input type="email" onChange={e => updateUseremail(e.target.value)} {...props} /> const Userpassword = ({updateUserpassword, ...props}) => <input type="password" onChange={e => updateUserpassword(e.target.value)} {...props} /> const SubmitButton = props => <button type="submit" {...props} /> const LoginForm = () => { // LoginForm狀態(tài)變化 => Useremail/Userpassword組件 const [email, setEmail] = React.useState(''); const [password, setPassword] = React.useState(''); const handleSubmit = (e) => { e.preventDefault(); alert(email + ' ' + password); }; return ( <form onSubmit={handleSubmit}> <div> <label htmlFor="email">Email</label> <Useremail id="email" type="text" value={email} updateUseremail={setEmail} /> </div> <div> <label htmlFor="password">Password</label> <Userpassword id="password" type="password" value={password} updateUserpassword={setPassword} /> </div> <SubmitButton type="submit">Submit</SubmitButton> </form> ); }; export { LoginForm };
實際執(zhí)行這兩個程序,得到的結(jié)果是一致,看起來兩者沒有什么區(qū)別
那為何不選擇雙向數(shù)據(jù)流
- 代碼維護
以上代碼可以發(fā)現(xiàn),一旦LoginForm發(fā)生問題,雙向數(shù)據(jù)流需要在多個子組件和父組件中同時尋找狀態(tài)異常的原因,當程序逐漸趨于復雜化,后期維護會變得異常困難
- 組件復用
每次用戶狀態(tài)需求發(fā)生新的變化,每個子組件都要相應調(diào)整,造成組件在實際使用中難以復用
- 應用升級
另外,當程序需要做整體升級,因為狀態(tài)分散在各個組件,將會導致難以實行
小結(jié)
組件設計成響應式,從長遠看,更符合React推薦的設計模式
原文鏈接:https://juejin.cn/post/7144227935996608549
相關推薦
- 2022-04-04 react報錯‘react-scripts‘ 不是內(nèi)部或外部命令,也不是可運行的程序
- 2022-08-13 微信公眾號--根據(jù)用戶的opneId發(fā)送模版消息
- 2022-01-20 localStorage 和 sessionStorage 及其用法 對象屬性操作方式
- 2022-09-15 Nginx如何獲取自定義請求header頭和URL參數(shù)詳解_nginx
- 2022-07-11 跨域的五種解決方案
- 2022-02-25 Oracle工具PL/SQL的基本語法_oracle
- 2023-01-01 c語言中實現(xiàn)數(shù)組幾個數(shù)求次大值_C 語言
- 2022-07-20 關于numpy強制類型轉(zhuǎn)換的問題_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支