React组件setState
注意:
1. 自定义组件首字母必须大写。这里是以函数表达式的方式定义子组件的。
2. 使用 ES6 的 class 关键字创建的 React 组件,组件中的方法遵循与常规 ES6 class 相同的语法规则。这意味着这些方法不会自动绑定 this 到这个组件实例。 你需要显式地调用 .bind(this)
一、setState(updater, [callback])
1. updater的实质是一个函数
setState((state, props) => ({quantity: state.quantity + 2}) ) // 返回的是状态改变对象,并与之前的state合并
但更多的时候,我们使用其简写形式,传入的是一个对象
setState({quantity: 2})
如果新的状态不依赖原始state, 使用简写(对象)方式;如果新的状态依赖原始State, 使用函数方式写。
2. setState() 并不总是立即更新组件。它会批量推迟更新。这使得在调用 setState() 后立即读取 this.state 成为了隐患。
为了能正确获取更新后的state数据,在componentDidUpdate 或者在setState 的回调函数callback中去获取state值,保证获取的state是更新后的值。
this.setState((state) => ({
quantity: state.quantity + 1
}), () => {
console.log('after state update', state.quantity);
}
)
3. setState()是同步的,还是异步的?
react相关的回调(声明周期、react事件监听回调):异步 其他异步回调(setTimeout, Promise.then事件回调 / await之后, DOM事件监听):同步
4. 多次调用异步的setState, 无论调用多少次setState,只执行一次render.
// 初始
this.state = {
count: 1
}
4.1 使用对象的方式(状态更新合并成一次)
update1 = () =》 {
this.setState({count : this.state.count +1});
this.setState({count : this.state.count +1});
}
// render中得到的state.count = 2
4.2 使用函数的形式(状态更新是多次进行的【updater 函数中接收的 state 和 props 都保证为最新】,render合并为一次)
update2 = () => {
this.setState((state) => ({
count: state.count + 1
})
this.setState((state) => ({
count: state.count + 1
})
}
// render中的结果为3(加法执行了两次)
4.3 混用对象形式和函数形式
update3 = () => {
// 先执行对象形式,后执行函数形式
this.setState({count : this.state.count +1});
this.setState((state) => ({
count : state.count +1
}));
}
// render中的state.count = 3
update4 = () => {
//先执行函数形式, 再执行对象形式
this.setState((state) => ({
count : state.count +1
}));
this.setState({count : this.state.count +1});
}
// render中的state.count = 2
拓展:面试题
class Test extends React.Component {
state = {
count: 0
};
// handleClick = () => {};
componentDidMount() {
// 异步
this.setState({
count: this.state.count + 1
});
this.setState({
count: this.state.count + 1 //
});
console.log(this.state.count); // 2==>0
// 异步
this.setState(state => ({ count: state.count + 1 })); //
this.setState(state => ({ count: state.count + 1 })); //
console.log(this.state.count); // 3==>0
setTimeout(() => {
this.setState({ count: this.state.count + 1 }); //
console.log("timeout", this.state.count); // 10==>6
this.setState({ count: this.state.count + 1 }); //
console.log("timeout", this.state.count); // 12==>7
});
Promise.resolve().then(value => {
this.setState({ count: this.state.count + 1 }); //
console.log("promise", this.state.count); // 6==>4
this.setState({ count: this.state.count + 1 }); //
console.log("promise", this.state.count); // 8==>5
});
}
render() {
const { count } = this.state;
console.log("render", count); // 1==>0 4==>3 5==>4 7==>5 9==>6 11=>7
return (
<div>
<p>{count}</p>
{/* <button onClick={() => this.handleClick}>更新</button> */}
</div>
);
}
}
注意:多个setState执行后,他们的组合结果一次性地传递给render进行重新渲染。
React组件setState的更多相关文章
- 在React组件unmounted之后setState的报错处理
最近在做项目的时候遇到一个问题,在 react 组件 unmounted 之后 setState 会报错.我们先来看个例子, 重现一下问题: class Welcome extends Compone ...
- React组件属性部类(propTypes)校验
React组件属性类型(propTypes)校验 Prop 验证 随着应用不断变大,保证组件被正确使用变得非常有用.为此我们引入propTypes.React.PropTypes 提供很多验证器 (v ...
- 野心勃勃的React组件生命周期
当你还在写着Angular指令,过滤器,注入,服务,提供者,视图模版的时候,是不是觉得很烦,好在这个时候,React已经神一样的出现在历史舞台. React组件 React实现了UI=Fn(St ...
- React组件生命周期过程说明
来自kiinlam github94 实例化 首次实例化 getDefaultProps getInitialState componentWillMount render componentDidM ...
- React组件系统、props与状态(state)
多个组件合成一个组件: var style = { fontSize: 20, color: '#ff0000' }; var WebSite = React.createClass({ rende ...
- React组件开发
目录: 属性:props 内联样式 状态记忆 : state 生命周期 访问DOM 表单输入 承接快速入门篇:http://www.cnblogs.com/jasonnode/p/4444504.ht ...
- React组件生命周期过程说明【转】
实例化 首次实例化 getDefaultProps getInitialState componentWillMount render componentDidMount 实例化完成后的更新 getI ...
- react组件什么周期记录,转的
react 的核心除了虚拟DOM,我想还有一个很重要的就是生命周期函数,理解生命周期函数,对写出合理的commponet很有帮助.下面总结一下我对生命周期函数的一些理解已经在项目过程中遇到的一些问题. ...
- React组件开发入门
React 组件开发入门 Introduction 本文组成: Ryan Clark文章Getting started with React的翻译. 博主的实践心得. React由Facebook的程 ...
随机推荐
- tp5--开发规范
在日常开发的过程中,写代码都要有一定的规范,不然可读取就太差了,所以为了以后的维护.对接,好的代码规定是必须的. 以下是我自己对自己提出的要求: 全部: 1) 每个方法都要写好备注(@retrun作 ...
- ajaxReturn案例
请查看:http://www.cnblogs.com/bushe/p/4625097.html 不用自己写json格式啦,直接拿这个用就可以啦
- Display a QMessageBox from a QThread
Emit a signal. Since you cannot do UI stuff in a Qthread, instead send your message as an argument o ...
- 闲置安卓设备搭建Linux服务器实现外网访问
title: 闲置安卓设备搭建Linux服务器实现外网访问 这是我搭过的第一个博客系统,写贴纪念一下 待博主整理好思路,将今天所用到的全部分享! 好吧,我就是穷.富人靠科技,穷人靠变异.我这种穷人是真 ...
- 学会HTML就可以找工作了
对编程小白来讲,想要学习门槛低,学习周期短,难度指数可忽略.短时间内可能找一份薪资不错编程相关工作,那就把HTML作为入门级语言吧. 网页设计师 (//upload-images.jianshu.io ...
- mybatis源码学习(二):SQL的执行过程
从上一篇文章中,我们了解到MapperMethod将SQL的执行交给了sqlsession处理.今天我们继续往下看处理的过程. SqlSession接口除了提供获取Configuration,Mapp ...
- CSDN排名及积分规则
博客排行榜排名分值=个人Blog全部随笔与文章的阅读数之和+个人Blog全部评论数之和*10+个人所发表的评论数之和*50 CSDN博客积分计算规则: 1.每公布一篇原创或者翻译文章:可获得10分. ...
- CF--思维练习--CodeForces - 220C Little Elephant and Shifts (STL模拟)
ACM思维题训练集合 The Little Elephant has two permutations a and b of length n, consisting of numbers from ...
- css实现水平垂直居中的几种方式
梳理下平时常用css水平垂直居中方式- 使用flex布局 HTML <div class="box"> <div class="child"& ...
- python-os.rmdir与shutil.rmtree的区别和用法
每次写脚本的时候,pycharm都会自动生成缓存文件__pycache__文件,在提交代码的时候还得挨个删除,于是自己写一小段代码自动循环删除此目录及下面的文件. 思路: 先将目录及其下的文件读取出来 ...