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

英文网站建设需求/排名nba

英文网站建设需求,排名nba,asp.net动态网站开发教程pdf,四川住房和城乡建设厅网站电话this.setState 如果需要修改this.state中的数据 必须调用this.setstate这个方法 这个方法里面有2个参数 参数1:类型 对象 key是this.state中的key值 val是修改后的数据 参数2:类型 函数 1、查看数据是否已经更新 2、可以获取到数据更新后的最新的DOM…

this.setState

 

如果需要修改this.state中的数据 必须调用this.setstate这个方法

这个方法里面有2个参数

参数1:类型 对象 key是this.state中的key值 val是修改后的数据

参数2:类型  函数 1、查看数据是否已经更新 2、可以获取到数据更新后的最新的DOM结构

 

书写方案1:this.setstate({},()=>{})

书写方案2:this.setstate(()=({}),()=>{})

 

关于 setState() 有三件事是你应该知道的。

 

1.不要直接修改 state(状态)

this.state.comment = 'Hello';

上述代码并不会重新渲染组件,需要使用this.setState()代替:

this.setState({comment: 'Hello'
});

需要注意的是唯一可以分配 this.state 的地方是构造函数。

 

 

2.state(状态) 更新可能是异步的

React 为了优化性能,有可能会将多个 setState() 调用合并为一次更新。

因为this.props和this.state 可能是异步更新的,你不能依赖他们的值计算下一个state(状态)。以下面的代码为例:

this.setState({counter: this.state.counter + this.props.increment,
});

 

我们并不能通过上述代码得到想要的值,为了弥补这个问题,使用另一种 setState() 的形式,接受一个函数。这个函数将接收前一个状态作为第一个参数,应用更新时的 props 作为第二个参数,代码如下:

this.setState((prevState, props) => ({counter: prevState.counter + props.increment
}));

 

 

3.state(状态)更新会被合并

当你调用 setState(), React 将合并你提供的对象到当前的状态中。所以当State是一个多键值的结构时,可以单独更新其中的一个,此时会进行“差分”更新,不会影响其他的属性值。

 

 

 

setState()的异步更新。

 

1.执行setState()之后干了什么?

setState()方法通过一个队列机制实现state更新,当执行setState()的时候,会将需要更新的state合并之后放入状态队列,而不会立即更新this.state(可以和浏览器的事件队列类比)。如果我们不使用setState而是使用this.state.key来修改,将不会触发组件的re-render。如果将this.state赋值给一个新的对象引用,那么其他不在对象上的state将不会被放入状态队列中,当下次调用setState()并对状态队列进行合并时,直接造成了state丢失。

 

2.setState()可以接受一个函数作为参数?

setState() 不仅能够接受一个对象作为参数,还能够接受一个函数作为参数。函数的参数即为 state 的前一个状态以及 props。

React文档中对setState的说明如下:

void setState (

      function|object nextState,

      [function callback]

)

上述代码的第二个参数是一个回调函数,在setState() 的异步操作结束并且组件已经重新渲染的时候执行。换句话说,我们可以通过这个回调来拿到更新的state的值。

 

3.执行setState()后能拿到最新的state值吗?

以前在写代码时候,总是遇到明明执行过setState(),但是state的值却不是最新的,那么如何解决这个问题呢?

因为setState()函数接受两个参数,一个是一个对象,就是设置的状态,还有一个是一个回调函数,是在设置状态成功之后执行的,所以我们可以通过回掉拿到最新的state值。代码如下:

复制代码

updateData = (newData) => {this.setState({ data: newData },() => {//这里打印的是最新的state值console.log(that.state.data);});
}

复制代码

 

4.setState()一定是异步更新吗? 

我们先来看看下面的代码:

function incrementMultiple() {this.setState({count: this.state.count + 1});this.setState({count: this.state.count + 1});this.setState({count: this.state.count + 1});
}

 

直观上来看,当上面的 incrementMultiple 函数被调用时,组件状态的 count 值被增加了3次,每次增加1,那最后 count 被增加了3。但是,实际上的结果只给 state 增加了1。

 

 

事实上,setState 方法与包含在其中的执行是一个很复杂的过程,从 React 最初的版本到现在,也有无数次的修改。它的工作除了要更动 this.state 之外,还要负责触发重新渲染,这里面要经过 React 核心 diff 算法,最终才能决定是否要进行重渲染,以及如何渲染。而且为了批次与效能的理由,多个 setState 呼叫有可能在执行过程中还需要被合并,所以它被设计以延时的来进行执行是相当合理的。

 

在 React 的 setState 函数实现中,会根据一个变量 isBatchingUpdates 判断是直接更新 this.state 还是放到队列中回头再说,而 isBatchingUpdates 默认是 false,也就表示 setState 会同步更新 this.state,但是,有一个函数 batchedUpdates,这个函数会把 isBatchingUpdates 修改为 true,而当 React 在调用事件处理函数之前就会调用这个 batchedUpdates,造成的后果,就是由 React 控制的事件处理过程 setState 不会同步更新 this.state。

 

 

由 React 控制的事件处理过程 setState 不会同步更新 this.state!

也就是说,在 React 控制之外的情况, setState 会同步更新 this.state!

但大部份的使用情况下,我们都是使用了 React 库中的表单组件,例如 select、input、button 等等,它们都是 React 库中人造的组件与事件,是处于 React 库的控制之下,比如组件原色 onClick 都是经过 React 包装。在这个情况下,setState 就会以异步的方式执行。

http://www.jmfq.cn/news/4788577.html

相关文章:

  • 烟台公司网站开发/网站推广业务
  • 做博彩网站犯法吗/湖北百度推广电话
  • 重庆网站建设网页设计/电商网站运营
  • 哪个网站做logo设计/如何在百度免费发布广告
  • 网络设计专业可以学什么/seo怎么推排名
  • 门户网站怎么建设/百度seo咋做
  • 免费一级做网站/绍兴seo推广
  • 网站建设与管理工资/可以入侵的网站
  • 此网站正在建设中/社交网络的推广方法有哪些
  • 辽宁响应式网站建设推荐/手机怎么在百度上发布信息
  • 毕业论文网站开发需要多少钱/8大营销工具指的是哪些
  • 网站设计介绍怎么写/网络推广推广
  • 山东省日照市有专业做网站的/长沙关键词优化方法
  • 迪虎科技网站建设/刚刚地震最新消息今天
  • 中国海关进出口信息查询/优化设计电子课本
  • wordpress邮箱如何解析/seo技术教程
  • 网站开发移动app/海外品牌推广
  • 做销售网站的好做么/seo入门教程视频
  • 上海网站建设费用多少/百度贴吧官网入口
  • 做网站跟app的区别/软文代发布
  • 监控视频怎么做直播网站/网站流量查询平台
  • 旅游找什么网站好/精准客源app
  • 网站建设公司武汉/品牌策略有哪些
  • 对视频播放网站做性能测试/抖音seo供应商
  • 电信网站备案流程图/蚁百杭州网站seo优化
  • 乐清 做网站 多少钱/百度有哪些app产品
  • 微信服务号菜单链接网站怎么做的/疫情放开最新消息今天
  • 学校html网站模板代码/淘宝关键词优化技巧
  • 做污事网站/想做电商怎么入手
  • 网站推广成功案例/中国百强企业榜单