react中的雙向綁定你真的了解嗎
前言:因?yàn)轫?xiàng)目原因需要學(xué)習(xí)另一個(gè)超級(jí)火的框架react, 因?yàn)橹耙恢笔褂胿ue進(jìn)行開(kāi)發(fā),所以在學(xué)習(xí)react中會(huì)不自覺(jué)的代入一些vue中的概念來(lái)理解react中的實(shí)現(xiàn),下面就通過(guò)對(duì)比學(xué)習(xí)的方式記錄下react中的知識(shí)。
在react中其實(shí)是沒(méi)有雙向綁定的概念,每次更新頁(yè)面和值都需要我們自己去調(diào)用指定的api來(lái)觸發(fā),而在vue中只需要使用v-model指令就可以完全實(shí)現(xiàn),在vue中的指令其實(shí)也是使用了幾個(gè)事件的語(yǔ)法糖來(lái)實(shí)現(xiàn),所以下面就去看下react中的“雙向綁定”是怎么來(lái)實(shí)現(xiàn)的。
如果實(shí)現(xiàn)react中得雙向綁定,首先要理解state這個(gè)屬性,簡(jiǎn)單來(lái)說(shuō)react中得state就是一個(gè)對(duì)象,它用來(lái)緩存和維護(hù)當(dāng)前組件中所使用到得狀態(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 (
<div>
<form onSubmit={handleSubmit}>
</form>
</div>
)
}
}
而在函數(shù)式組件中,使用hooks可以將這個(gè)統(tǒng)一的state值根據(jù)功能和場(chǎng)景拆分為多個(gè)state用來(lái)更加方便的使用和維護(hù),如:
import React, { useState } from 'react'
export default function ModelChange() {
const [name, setName] = useState('')
const [age, setAge] = useState()
const handleSubmit = () => {
}
return (
<div>
<form onSubmit={handleSubmit}>
</form>
</div>
)
}
需要注意的是,如果需要改變維護(hù)的狀態(tài)的值,需要使用指定的方法才會(huì)使頁(yè)面更新,如函數(shù)式組件中定義的setName方法等。下面就看看react在input輸入框中實(shí)現(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 (
<div>
<form>
<label>
名字:
<input type="text" value={name} onChange={handleCnhange} />
</label>
</form>
</div>
)
}
上面的代碼通過(guò)useState定義了值name,然后通過(guò)input標(biāo)簽的value將name展示出來(lái),通過(guò)監(jiān)聽(tīng)change事件獲取輸入的值并調(diào)用定義好的方法setName修改name的值并更新頁(yè)面,又使頁(yè)面展示為新輸入的值,通過(guò)這個(gè)流程的操作就實(shí)現(xiàn)了在react中的雙向綁定。如果我們想要修改和獲取多個(gè)輸入的值可以使用name屬性來(lái)實(shí)現(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 (
<div>
<form>
<label>
名字:
<input type="text" name="name" value={data.name} onChange={handleCnhange} />
</label>
<label>
年齡:
<input type="text" name="age" value={data.age} onChange={handleCnhange} />
</label>
<input type="button" value="提交" onClick={handleSubmit} />
</form>
</div>
)
}
上面代碼將name和age字段聲明在了一個(gè)集合中(根據(jù)業(yè)務(wù)和使用場(chǎng)景也可以進(jìn)行拆分定義),通過(guò)給input標(biāo)簽添加name屬性來(lái)更給指定屬性更新當(dāng)前輸入的值,效果如下:

總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
react創(chuàng)建項(xiàng)目啟動(dòng)報(bào)錯(cuò)的完美解決方法
這篇文章主要介紹了react創(chuàng)建項(xiàng)目啟動(dòng)報(bào)錯(cuò)的完美解決方法,全稱為Node Package Manager,是隨同NodeJS一起安裝的包管理工具,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
淺談React的React.FC與React.Component的使用
本文主要介紹了React的React.FC與React.Component的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
Header組件熱門(mén)搜索欄的實(shí)現(xiàn)示例
這篇文章主要為大家介紹了Header組件熱門(mén)搜索欄的實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
React中使用Redux Toolkit狀態(tài)管理的示例詳解
在現(xiàn)代 React 應(yīng)用程序中,狀態(tài)管理是一個(gè)至關(guān)重要的部分,使用 Redux Toolkit 可以簡(jiǎn)化 Redux 的配置和管理,本文將通過(guò)三個(gè)文件的示例,詳細(xì)講解如何使用 Redux Toolkit 創(chuàng)建和管理一個(gè)簡(jiǎn)單的計(jì)數(shù)器狀態(tài),需要的朋友可以參考下2024-11-11
React+Typescript創(chuàng)建項(xiàng)目的實(shí)現(xiàn)步驟
通過(guò)React組件庫(kù)和TypeScript的強(qiáng)類(lèi)型特性,開(kāi)發(fā)者可以創(chuàng)建出具有優(yōu)秀用戶體驗(yàn)和穩(wěn)定性的Web應(yīng)用程序,本文主要介紹了React+Typescript創(chuàng)建項(xiàng)目的實(shí)現(xiàn)步驟,感興趣的可以了解一下2023-08-08
react常見(jiàn)的ts類(lèi)型實(shí)踐解析
這篇文章主要為大家介紹了react常見(jiàn)的ts類(lèi)型實(shí)踐解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
React中實(shí)現(xiàn)組件通信的幾種方式小結(jié)
在構(gòu)建復(fù)雜的React應(yīng)用時(shí),組件之間的通信是至關(guān)重要的,從簡(jiǎn)單的父子組件通信到跨組件狀態(tài)同步,不同組件之間的通信方式多種多樣,下面我們認(rèn)識(shí)react組件通信的幾種方式,需要的朋友可以參考下2024-04-04

