網(wǎng)站首頁 編程語言 正文
前言:因為項目原因需要學習另一個超級火的框架react, 因為之前一直使用vue進行開發(fā),所以在學習react中會不自覺的代入一些vue中的概念來理解react中的實現(xiàn),下面就通過對比學習的方式記錄下react中的知識。
在react中其實是沒有雙向綁定的概念,每次更新頁面和值都需要我們自己去調(diào)用指定的api來觸發(fā),而在vue中只需要使用v-model指令就可以完全實現(xiàn),在vue中的指令其實也是使用了幾個事件的語法糖來實現(xiàn),所以下面就去看下react中的“雙向綁定”是怎么來實現(xiàn)的。
如果實現(xiàn)react中得雙向綁定,首先要理解state這個屬性,簡單來說react中得state就是一個對象,它用來緩存和維護當前組件中所使用到得狀態(tài),可以理解為vue中data中定義得值,如:
import React, { Component } from 'react' export default class Class extends Component { constructor(props) { super(props) this.state = {name: '', age: ''} } render() { return () } }
而在函數(shù)式組件中,使用hooks可以將這個統(tǒng)一的state值根據(jù)功能和場景拆分為多個state用來更加方便的使用和維護,如:
import React, { useState } from 'react' export default function ModelChange() { const [name, setName] = useState('') const [age, setAge] = useState() const handleSubmit = () => { } return () }
需要注意的是,如果需要改變維護的狀態(tài)的值,需要使用指定的方法才會使頁面更新,如函數(shù)式組件中定義的setName方法等。下面就看看react在input輸入框中實現(xiàn)雙向綁定,代碼如下:
import React, { useState } from 'react' export default function ModelChange() { const [name, setName] = useState('') const handleCnhange = e => { const data = e.target.value setName(data) } return () }
上面的代碼通過useState定義了值name,然后通過input標簽的value將name展示出來,通過監(jiān)聽change事件獲取輸入的值并調(diào)用定義好的方法setName修改name的值并更新頁面,又使頁面展示為新輸入的值,通過這個流程的操作就實現(xiàn)了在react中的雙向綁定。如果我們想要修改和獲取多個輸入的值可以使用name屬性來實現(xiàn),代碼如下:
import React, { useState } from 'react' export default function ModelChange() { const [data, setData] = useState({ name: '', age: '' }) const handleCnhange = e => { const {value, name} = e.target setData(preData => { return { ...preData, [name]: value } }) } const handleSubmit = (e) => { console.log(data) } return () }
上面代碼將name和age字段聲明在了一個集合中(根據(jù)業(yè)務和使用場景也可以進行拆分定義),通過給input標簽添加name屬性來更給指定屬性更新當前輸入的值,效果如下:
總結
原文鏈接:https://blog.csdn.net/weixin_43911758/article/details/123312684
相關推薦
- 2022-11-20 Golang交叉編譯之跨平臺編譯使用詳解_Golang
- 2022-10-01 iOS實現(xiàn)UIButton的拖拽功能_IOS
- 2022-06-01 Apache?Tomcat如何高并發(fā)處理請求_Tomcat
- 2024-01-10 給idea添加右鍵打開功能
- 2022-05-10 一文帶你了解中Typescript中type與interface的區(qū)別
- 2022-12-08 C語言帶頭雙向循環(huán)鏈表的示例代碼_C 語言
- 2022-03-17 .NET?6開發(fā)TodoList應用引入數(shù)據(jù)存儲_實用技巧
- 2023-10-16 Nginx啟動,重啟以及基本命令
- 最近更新
-
- 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之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支