欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react中的雙向綁定你真的了解嗎

 更新時間:2022年03月07日 16:38:08   作者:前端三腳貓  
這篇文章主要為大家詳細介紹了react中的雙向綁定,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

前言:因為項目原因需要學(xué)習(xí)另一個超級火的框架react, 因為之前一直使用vue進行開發(fā),所以在學(xué)習(xí)react中會不自覺的代入一些vue中的概念來理解react中的實現(xiàn),下面就通過對比學(xué)習(xí)的方式記錄下react中的知識。

在react中其實是沒有雙向綁定的概念,每次更新頁面和值都需要我們自己去調(diào)用指定的api來觸發(fā),而在vue中只需要使用v-model指令就可以完全實現(xiàn),在vue中的指令其實也是使用了幾個事件的語法糖來實現(xiàn),所以下面就去看下react中的“雙向綁定”是怎么來實現(xiàn)的。

如果實現(xiàn)react中得雙向綁定,首先要理解state這個屬性,簡單來說react中得state就是一個對象,它用來緩存和維護當(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可以將這個統(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 (
    <div>
      <form onSubmit={handleSubmit}>
      </form>
    </div>
  )
}

需要注意的是,如果需要改變維護的狀態(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 (
    <div>
      <form>
        <label>
          名字:
          <input type="text" value={name} onChange={handleCnhange} />
        </label>
      </form>
    </div>
  )
}

上面的代碼通過useState定義了值name,然后通過input標(biāo)簽的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 (
    <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字段聲明在了一個集合中(根據(jù)業(yè)務(wù)和使用場景也可以進行拆分定義),通過給input標(biāo)簽添加name屬性來更給指定屬性更新當(dāng)前輸入的值,效果如下:

在這里插入圖片描述

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容! 

相關(guān)文章

  • React自定義hooks同步獲取useState的最新狀態(tài)值方式

    React自定義hooks同步獲取useState的最新狀態(tài)值方式

    這篇文章主要介紹了React自定義hooks同步獲取useState的最新狀態(tài)值方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 可定制react18 input otp 一次性密碼輸入組件

    可定制react18 input otp 一次性密碼輸入組件

    這篇文章主要為大家介紹了可定制react18 input otp 一次性密碼輸入組件,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • React組件重構(gòu)之嵌套+繼承及高階組件詳解

    React組件重構(gòu)之嵌套+繼承及高階組件詳解

    這篇文章主要給大家介紹了關(guān)于React組件重構(gòu)之嵌套+繼承及高階組件的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07
  • 深入理解React與閉包的關(guān)系

    深入理解React與閉包的關(guān)系

    本文將深入探討React與閉包之間的關(guān)系,我們將首先介紹React和閉包的基本概念,然后詳細解釋React組件中如何使用閉包來處理狀態(tài)和作用域的問題,希望通過本文的閱讀,你將對React中閉包的概念有更深入的理解,并能夠在開發(fā)React應(yīng)用時更好地應(yīng)用閉包
    2023-07-07
  • react合成事件與原生事件的相關(guān)理解

    react合成事件與原生事件的相關(guān)理解

    本文主要介紹了react合成事件與原生事件的相關(guān)概念,幫助大家區(qū)分這兩種事件,學(xué)習(xí)react的同學(xué)不妨了解下
    2021-05-05
  • ReactNative集成個推消息推送過程詳解

    ReactNative集成個推消息推送過程詳解

    這篇文章主要為大家介紹了ReactNative集成個推消息推送過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • React項目搭建與Echarts工具使用詳解

    React項目搭建與Echarts工具使用詳解

    這篇文章主要介紹了React項目搭建與Echarts工具使用詳解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • React Native實現(xiàn)進度條彈框的示例代碼

    React Native實現(xiàn)進度條彈框的示例代碼

    本篇文章主要介紹了React Native實現(xiàn)進度條彈框的示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • React?Native?的動態(tài)列表方案探索詳解

    React?Native?的動態(tài)列表方案探索詳解

    這篇文章主要為大家介紹了React?Native?的動態(tài)列表方案探索示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • react實現(xiàn)復(fù)選框全選和反選組件效果

    react實現(xiàn)復(fù)選框全選和反選組件效果

    這篇文章主要為大家詳細介紹了react實現(xiàn)復(fù)選框全選和反選組件效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08

最新評論