站长家园(原代码之家)(www.adminjie.com)网站源码,微信源码,游戏源码,商业源码分享平台。
当前位置:网站首页 技术文章 网络编程 正文

react中的setstate是什么

时间:2022-04-22 [网络编程]作者:fabuyuan 浏览:9 次

react中,setstate是用于更新组件状态state的方法;setState()将对组件state的更改排入队列,并通知React需要使用更新后的state重新渲染此组件及其子组件,语法为“setState(对象,[回调函数])”。

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react中的setstate是什么

根据平时的使用来看,我们基本上会使用它来更新组件的状态state。根据网文档的解释:

setState() 将对组件 state 的更改排入队列,并通知 React 需要使用更新后的 state 重新渲染此组件及其子组件。这是用于更新用户界面以响应事件处理器和处理服务器数据的主要方式.

将 setState() 视为请求而不是立即更新组件的命令。为了更好的感知性能,React 会延迟调用它,然后通过一次传递更新多个组件。React 并不会保证 state 的变更会立即生效。

按其解释,setState的作用是把组件的state更新任务排入任务队列,而不是调用就立即更新state状态,即将setState看做请求而不是立即更新组件的命令。所以在调用setState方法后就去取组件的state的值时,会取到没有更新的值。

setState() 并不总是立即更新组件。它会批量推迟更新。这使得在调用 setState() 后立即读取 this.state 成为了隐患。为了消除隐患,请使用 componentDidUpdate 或者 setState 的回调函数(setState(updater, callback)),这两种方式都可以保证在应用更新后触发。

使用

setState(updater, [callback]),

updater为返回stateChange对象的函数: (state, props) => stateChange

this.setState(state => ({count: state.count + 1}), () => { 
// 在状态更新且界面更新之后回调
        console.log('test3 setState callback()', this.state.count)
      })
setState(stateChange, [callback])

stateChange为对象,

callback是可选的回调函数, 在状态更新且界面更新后才执行

this.setState({count: this.state.count + 1}), () => {
 // 在状态更新且界面更新之后回调
        console.log('test3 setState callback()', this.state.count)
      })

总结:

对象方式是函数方式的简写方式

如果新状态不依赖于原状态 ===> 使用对象方式

如果新状态依赖于原状态 ===> 使用函数方式

如果需要在setState()后获取最新的状态数据, 在第二个callback函数中读取

推荐学习:《react视频教程

以上就是react中的setstate是什么的详细内容,更多请关注站长家园其它相关文章!

本文标签:  React

转载请注明来源:react中的setstate是什么

本文永久链接地址:https://www.adminjie.com/post/11496.html

免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。

  • 站长家园(原代码之家)会员升级
  • 最新文章
    • oracle怎么删除session

      oracle怎么删除session

      删除session的方法:1、利用“v$session”视图,查看会话的sid和“serial#”;2、利用alter语句删除session即可,语法为“alt...

    • oracle怎么关闭em

      oracle怎么关闭em

      方法:1、用“emctlstatusdbconsole”查看em状态;2、用“emctlstopdbconsole”使em停止运行;3、用“emca-...

    • jquery怎么添加和移除元素

      jquery怎么添加和移除元素

      添加元素的方法:1、用append()或prepend()在指定元素内部添加子元素;2、用after()或before()添加同级元素。移除方法:1、用remo...

    • oracle怎么实现读写分离

      oracle怎么实现读写分离

      实现读写分离的方法:1、利用Oracle自身组件,包括Physical方式支持的异步传输方式和logical方式支持的同步传输方式;2、利用第三方组件,包括Sh...

    • 什么是jquery异步加载

      什么是jquery异步加载

      在jquery中,异步加载又称为非阻塞加载,一般指在加载的同时执行代码;也就是当浏览器在加载JQ或JS的同时,还会进行后续页面处理,这样可以优化脚本文件的加载,...

    热门文章