亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React中setState/useState的使用方法詳細(xì)介紹

 更新時(shí)間:2023年04月06日 10:00:32   作者:英俊瀟灑美少年  
這篇文章主要介紹了React中setState/useState的使用方法,useState 和 setState 在React開(kāi)發(fā)過(guò)程中 使用很頻繁,但很多人都停留在簡(jiǎn)單的使用階段,并沒(méi)有正在了解它們的執(zhí)行機(jī)制

一、React如何使用setState/useState的最新的值

一般是可以正常的把最新的值,傳遞給所需要的函數(shù)中的,但是有些情況,需要使用最新數(shù)據(jù)的函數(shù),不可改動(dòng),甚至所需要使用的地方并不是一個(gè)函數(shù),那我們?nèi)绾潍@取setState/useState的最新的值呢?

A.使用setState的最新的值

1、setState方法可以接收兩個(gè)參數(shù),第一個(gè)參數(shù)為一個(gè)對(duì)象,第二個(gè)參數(shù)為一個(gè)函數(shù),即更新成功后執(zhí)行的回調(diào)函數(shù)。我們可以在回調(diào)函數(shù)中獲取更新后的值。

import React, { Component } from 'react'
export default class DemoClassComp extends Component {
  constructor(props) {
    super(props)
    this.state = {
      number: 1,
    }
  }
  inControl = ()=>{
    this.setState({number: 1}, () => {
      console.log('%c ?? DemoClassComp -> inControl -> this.state.number ', 'font-size:16px;background-color:#f31440;color:white;', this.state.number)
    })
  }
  render() {
    return (
      <div>
        <button onClick={this.inControl} >點(diǎn)我</button>
      </div>
    )
  }
}

2、使用setTimeout

B.使用useState的最新的值

1、使用另一個(gè)Hook,useRef;

function DemoFuncComp() {
  const [qimingFlag, setQimingFlag] = useState(false);
  const qimingFlagRef = useRef(false);
  const handleLine = () => {
    deleteQimingFieldsData(data, qimingFlagRef?.current); //* 刪除啟明相關(guān)字段的數(shù)據(jù)
  }
  const initData = useCallback(async () => {
    await commonQuery(basicInfoHeader, { contractId });
    const qimingFlagNow = basicInfoHeader.current?.get('qimingFlag');
    setQimingFlag(qimingFlagNow); //* 用于出發(fā)重新渲染
    qimingFlagRef.current = qimingFlagNow;
    handleLine(); //* 要求 先setQimingFlag
  }, [contractId])
  /**生命周期 */
  useEffect(() => {
    initData();
  }, [contractId]);
  return (
    <>
      <Form dataSet={basicInfoHeader} disabled={true} columns={4}>
        <Lov name="receiverObj" />
    </Form>
    </>
  )
}

2、使用setTimeout

二、React中setState/useState執(zhí)行的同步異步問(wèn)題

只要代碼進(jìn)入了 react調(diào)度流程,那就是異步的。

只要代碼沒(méi)有進(jìn)入 react調(diào)度流程,那就是同步的。

setTimeout、setInterval、async中await的后續(xù)部分,Promise.then(),以及直接在 DOM 上綁定原生事件等。這些都不會(huì)走 React調(diào)度流程,在這種情況下調(diào)用 setState ,那這次 setState 就是同步的。 否則就是異步的。

連續(xù)執(zhí)行兩個(gè) useState

function DemoFuncComp() {
  const [a, setA] = useState(0);
  const [b, setB] = useState(0);
  console.log('render')
  function outControl() {
    Promise.resolve().then(() => {
      setA((a) => a + 1);
      setB((b) => b + 1);
    })
  }
  function inControl() {
    setA((a) => a + 1);
    setB((b) => b + 1);
  }
  return (
    <>
      <button onClick={outControl} >{a}- 【不受react調(diào)度】</button>
      <button onClick={inControl} >{a}- 【react調(diào)度】</button>
    </>
  )
}
//! 當(dāng)點(diǎn)擊【不受react調(diào)度】按鈕時(shí),render 了兩次
//! 當(dāng)點(diǎn)擊【react調(diào)度】按鈕時(shí),只重新 render 了一次

連續(xù)執(zhí)行兩次同一個(gè) useState

function DemoFuncComp() {
  const [a, setA] = useState(1)
  console.log('a', a)
  function outControl() {
    Promise.resolve().then(() => {
      setA((a) => a + 1)
      setA((a) => a + 1)
    })
  }
  function inControl() {
    setA((a) => a + 1)
    setA((a) => a + 1)
  }
  return (
    <>
      <button onClick={outControl} >{a} 【不受react調(diào)度】</button>
      <button onClick={inControl} >{a} 【react調(diào)度】</button>
    </>
  )
}
//! 當(dāng)點(diǎn)擊【不受react調(diào)度】按鈕時(shí),兩次 setA 各自 render 一次,分別打印 2,3
//! 當(dāng)點(diǎn)擊【react調(diào)度】按鈕時(shí),兩次 setA 都執(zhí)行,但合并 render 了一次,打印 3

連續(xù)執(zhí)行兩個(gè) setState

class DemoClassComp extends React.Component {
  constructor(props) {
    super(props)
    this.state = {
      a: 1,
      b: 'b',
    }
  }
  outControl = () => {
    Promise.resolve().then(() => {
      this.setState({...this.state, a: 'aa'})
      this.setState({...this.state, b: 'bb'})
    })
  }
  inControl = () => {
    this.setState({...this.state, a: 'aa'})
    this.setState({...this.state, b: 'bb'})
  }
  render() {
    console.log('render')
    return (
      <>
        <button onClick={this.outControl} >【不受react調(diào)度】</button>
        <button onClick={this.inControl} >【react調(diào)度】</button>
      </>
    )
  }
}
//! 當(dāng)點(diǎn)擊【不受react調(diào)度】按鈕時(shí),render 了兩次
//! 當(dāng)點(diǎn)擊【react調(diào)度】按鈕時(shí),只重新 render 了一次

連續(xù)執(zhí)行兩次同一個(gè) setState

class DemoClassComp extends React.Component {
  constructor(props) {
    super(props)
    this.state = {
      a: 1,
    }
  }
  outControl = () => {
    Promise.resolve().then(() => {
      this.setState({a: this.state.a + 1})
      this.setState({a: this.state.a + 1})
    })
  }
  inControl = () => {
    this.setState({a: this.state.a + 1})
    this.setState({a: this.state.a + 1})
  }
  render() {
    console.log('a', this.state.a)
    return (
      <>
        <button onClick={this.outControl} >【不受react調(diào)度】</button>
        <button onClick={this.inControl} >【react調(diào)度】</button>
      </>
    )
  }
}
//! 當(dāng)點(diǎn)擊【不受react調(diào)度】按鈕時(shí),兩次 setState 各自 render 一次,分別打印 2,3
//! 當(dāng)點(diǎn)擊【react調(diào)度】按鈕時(shí),兩次 setState 合并,只執(zhí)行了最后一次,打印 2

總結(jié)

在正常的react調(diào)度流程中時(shí):

  • setState和useState都是異步執(zhí)行的
  • 多次執(zhí)行setState和useState,會(huì)進(jìn)行一次batchUpdate,只會(huì)重新渲染render一次
  • 不同的是,多次執(zhí)行,setState會(huì)進(jìn)行state的合并,而useState每次運(yùn)行都會(huì)重新計(jì)算

不再react調(diào)度流程中時(shí)

  • setState和useState是同步執(zhí)行的(立即更新state,觸發(fā)render,然后繼續(xù)執(zhí)行)
  • 多次執(zhí)行setState和useState,每一次的執(zhí)行setState和useState,都會(huì)調(diào)用一次render

到此這篇關(guān)于React中setState/useState的使用方法詳細(xì)介紹的文章就介紹到這了,更多相關(guān)React setState/useState內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • react時(shí)間分片實(shí)現(xiàn)流程詳解

    react時(shí)間分片實(shí)現(xiàn)流程詳解

    實(shí)現(xiàn)react時(shí)間分片,主要內(nèi)容包括什么是時(shí)間分片、為什么需要時(shí)間分片、實(shí)現(xiàn)分片開(kāi)啟 - 固定、實(shí)現(xiàn)分片中斷、重啟 - 連續(xù)、分片重啟、實(shí)現(xiàn)延遲執(zhí)行 - 有間隔、時(shí)間分片異步執(zhí)行方案的演進(jìn)、時(shí)間分片簡(jiǎn)單實(shí)現(xiàn)、總結(jié)、基本概念、基礎(chǔ)應(yīng)用、原理機(jī)制和需要注意的事項(xiàng)等
    2022-11-11
  • React 全自動(dòng)數(shù)據(jù)表格組件——BodeGrid的實(shí)現(xiàn)思路

    React 全自動(dòng)數(shù)據(jù)表格組件——BodeGrid的實(shí)現(xiàn)思路

    表格是在后臺(tái)管理系統(tǒng)中用的最頻繁的組件之一,相關(guān)的功能有數(shù)據(jù)的新增和編輯、查詢(xún)、排序、分頁(yè)、自定義顯示以及一些操作按鈕。這篇文章主要介紹了React 全自動(dòng)數(shù)據(jù)表格組件——BodeGrid ,需要的朋友可以參考下
    2019-06-06
  • React組件學(xué)習(xí)之Hooks使用

    React組件學(xué)習(xí)之Hooks使用

    這篇文章主要介紹了React hooks組件通信,在開(kāi)發(fā)中組件通信是React中的一個(gè)重要的知識(shí)點(diǎn),本文通過(guò)實(shí)例代碼給大家講解react hooks中常用的父子、跨組件通信的方法,需要的朋友可以參考下
    2022-08-08
  • 淺談React Event實(shí)現(xiàn)原理

    淺談React Event實(shí)現(xiàn)原理

    這篇文章主要介紹了淺談React Event實(shí)現(xiàn)原理,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • react組件多次渲染問(wèn)題的解決

    react組件多次渲染問(wèn)題的解決

    本文主要介紹了react組件多次渲染問(wèn)題的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • 想用好React的你必須要知道的一些事情

    想用好React的你必須要知道的一些事情

    現(xiàn)在最熱門(mén)的前端框架,毫無(wú)疑問(wèn)是 React 。下面這篇文章主要給大家分享了關(guān)于想用好React的你必須要知道的一些事情,文中介紹的非常詳細(xì),對(duì)大家具有一定參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-07-07
  • react國(guó)際化化插件react-i18n-auto使用詳解

    react國(guó)際化化插件react-i18n-auto使用詳解

    這篇文章主要介紹了react國(guó)際化化插件react-i18n-auto使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • React受控組件與非受控組件深入講解

    React受控組件與非受控組件深入講解

    具體來(lái)說(shuō)這是一種react非受控組件,其狀態(tài)是在input的react內(nèi)部控制,不受調(diào)用者控制??梢允褂檬芸亟M件來(lái)實(shí)現(xiàn)。下面就說(shuō)說(shuō)這個(gè)React中的受控組件與非受控組件的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2022-12-12
  • Electron+React進(jìn)行通信的方法

    Electron+React進(jìn)行通信的方法

    electron其實(shí)是一個(gè)桌面應(yīng)用程序,不是一個(gè)標(biāo)準(zhǔn)的前端web程序,所有沒(méi)有什么請(qǐng)求的發(fā)生,控制臺(tái)network看不到請(qǐng)求,而是只能通過(guò)console.log去打印查看,而且通信協(xié)議使用的不是http而是gRPC協(xié)議,這篇文章主要介紹了Electron+React如何進(jìn)行通信,需要的朋友可以參考下
    2022-06-06
  • React?Hook?四種組件優(yōu)化總結(jié)

    React?Hook?四種組件優(yōu)化總結(jié)

    這篇文章主要介紹了React?Hook四種組件優(yōu)化總結(jié),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)孩子,需要的朋友可以參考一下
    2022-07-07

最新評(píng)論