当前位置: 首页 > news >正文

建站吗官方网站研究网站开发意义

建站吗官方网站,研究网站开发意义,武当王也高清壁纸,网站建设单位有哪些ReactHook中useState异步回调获取不到最新值及解决⽅案 预先了解 setState 的两种传参⽅式 1、直接传⼊新值 setState(options); 列如: const [state, setState] useState(0); setState(state 1); 2、传⼊回调函数 setState(callBack); 例如: …

ReactHook中useState异步回调获取不到最新值及解决⽅案

预先了解 setState 的两种传参⽅式

1、直接传⼊新值 setState(options);

列如:

const [state, setState] = useState(0);

setState(state + 1);

2、传⼊回调函数 setState(callBack);

例如:

const [state, setState] = useState(0);

setState((prevState) => prevState + 1); // prevState 是改变之前的 state 值,return 返回的值会作为新状态覆盖 state 值

useState 异步回调获取不到最新值及解决⽅案

通常情况下 setState 直接使⽤上述第⼀种⽅式传参即可,但在⼀些特殊情况下第⼀种⽅式会出现异常;

例如希望在异步回调或闭包中获取最新状态并设置状态,此时第⼀种⽅式获取的状态不是实时的,React 官⽅⽂档提到:组件内部的任何函数,包括事件处理函数和 Effect,都是从它被创建的那次渲染中被「看到」的,所以引⽤的值任然是旧的,最后导致 setState 出现异常:

import React, { useState, useEffect } from 'react';

const App = () => {

const [arr, setArr] = useState([0]);

useEffect(() => {

console.log(arr);

}, [arr]);

const handleClick = () => {

Promise.resolve().then(() => {

setArr([...arr, 1]); // 此时赋值前 arr 为:[0]

})

.then(() => {

setArr([...arr, 2]); // 此时赋值前 arr 为旧状态仍然为:[0]

});

}

return (

<>

<button onClick={handleClick}>change</button>

</>

);

}

export default App;

上⾯代码,App 组件实际也是个闭包函数,handleClick ⾥⾯引⽤着 arr,第⼀次 setArr 后 arr 的值确实更新了,我们也可以在下⾯截图中看到,但此次执⾏的 handleClick 事件处理函数作⽤域还是旧的,⾥⾯引⽤的 arr 仍然为旧的,导致第⼆次 setArr 后结果为 [0, 2]:

在 class 组件中我们可以使⽤ setState(options, callBack); 在 setState 的第⼆个参数回调函数中再次进⾏ setState,也不存在闭包作⽤域问题,但是 React Hook 中 useState 移除了 setState 的第⼆个参数,⽽且若嵌套太多也不佳;

解决⽅案1(推荐使⽤):

将上述代码使⽤第⼆种(回调)⽅式传参

const handleClick = () => {

Promise.resolve().then(() => {

setArr(prevState => [...prevState, 1]); // 这⾥也可以不改,使⽤第⼀中传参⽅式 setArr([...arr, 1]); 因为这⾥不需要获取最新状态

})

.then(() => {

setArr(prevState => [...prevState, 2]); // 这⾥必须改成回调函数传参⽅式,否则会读取旧状态,导致异常

});

}

解决⽅案2:

使⽤ useReducer 仿造类组件中的 forceUpdate 实现组件强制渲染;

import React, { useState, useReducer } from 'react';

const App = () => {

const [arr, setArr] = useState([0]);

const [, forceUpdate] = useReducer(x => x + 1, 0);

const handleClick = () => {

Promise.resolve().then(() => {

arr.push(1); // 如果这⾥也需要做⼀次渲染在改变状态后调⽤ forceUpdate() 即可 })

.then(() => {

arr.push(2);

forceUpdate();

});

}

return (

<>

<h1>{arr.toString()}</h1>

<button onClick={handleClick}>change</button>

</>

);

}

export default App;

点击前:

点击后:

解决⽅案3:

利⽤ ref

import React, { useState, useRef, useEffect } from 'react';

const App = () => {

const [arr, setArr] = useState([0]);

let ref = useRef();

useEffect(() => {

ref.current = arr;

console.log(arr);

});

const handleClick = () => {

Promise.resolve().then(() => {

const now = [...ref.current, 1];

ref.current = now;

setArr(now);

})

.then(() => {

setArr([...ref.current, 2]);

});

}

return (

<>

<h1>{arr.toString()}</h1>

<button onClick={handleClick}>change</button>

</>

);

}

export default App;

http://www.yayakq.cn/news/483428/

相关文章:

  • html在线编写网站天津做网站哪个公司好
  • 国外有哪些设计网站有哪些问题郑州百度快照优化
  • 企业信息系统的作用南通网站优化
  • 做阿里巴巴网站需要多少钱网站建设会遇到哪些难题
  • 高平市网站建设公司知彼网络网站建设
  • 京东网站的设计特点百合怎么做网站
  • html购物网站模板下载电子商务网站开发与设计报告
  • 上饶招聘网站建设公司上海猎头公司收费标准
  • 做的网站怎样评估价值工具类网站做排名
  • 企业网站开发 外文文献会员卡管理系统设计
  • 3d网站开发成本宁波奉化建设局网站
  • 网站建设需要方案凡科网代理登录
  • 杭州兼职网站建设舟山网页设计
  • 网站3d展示怎么做全国注册室内设计师网
  • 国家建设厅网站设计网站的一般过程
  • 网站建设选择数据库wordpress怎么跟vue
  • 网站佣金怎么做会计分录王者荣誉网站怎么做
  • 建公司网站步骤岳阳棋牌软件定制开发公司
  • wordpress15天教网站优化公司上海
  • 江西app网站建设手机软件开发培训班
  • 比较好的做网站创做阿里巴巴网站流程
  • 做结婚视频储存网站wordpress layer
  • devexpress网站开发58同城网站模板下载
  • wordpress使用新浪图床郑州厉害的seo顾问
  • 胶州国际网站建设效果深圳做网站网络营销公司
  • 北京网站制作西安网站备份 ftp
  • 网畅学校网站管理系统怎样做企业手机网站建设
  • 深圳网站建设李天亮平面设计app推荐
  • 柳州网站开发公司仿36氪wordpress
  • 遂溪网站建设公司广州做公司网站