React 入门学习笔记整理(五)—— state
1、state
1)组件本省也是有状态的,定义在组件内部的state中,state的状态只能由组件自身改变,任何其他组件都不能改变。
当需要改变state时,通过调用setState方法来改变,setState会导致组件重新渲染。
class GreateH extends React.Component{
constructor(props){
super(props);
this.state ={
name:'CoCo'
}
}
handler(params){
this.setState({
name:params
})
};
render(){
return <div>
<h2 onClick={this.handler.bind(this,'kristy')}>hello,{this.state.name}</h2>
</div>
}
}
2)状态更新可能是异步的
import React,{Component} from "react";
class Test extends Component{
constructor(props){
super(props);
this.state = {
num:1
}
}
add = () => {
this.setState({
num:this.state.num+1
})
console.log(this.state.num);
}
render(){
return (
<div>
<p>{this.state.num}</p>
<button onClick={this.add}>点击累加</button>
</div>
)
}
}
export default Test;
我点击时,可以看到页面上的this.state.num数值变了,由1变成2,但是打印出来的this.state.num还是1,可以得出在事件中是异步的。

下面再举例说明:
add = () => {
this.setState({
num:this.state.num+1
});
this.setState({
num:this.state.num+2
});
console.log(this.state.num);
}
页面更新后的值是3,控制台打印出来的结构是1,因为是异步的,所以无法通过上一个状态去计算下一个状态。而更新的结果是3不是4,这是因为setState中会合并操作。如果想要避免这种情况,就需要在setState传入一个函数,如下所示:
add = () => {
this.setState((state)=>{
return {
num:state.num +1
}
});
this.setState((state)=>{
return {
num:state.num +2
}
});
console.log(this.state.num);
}
这个时候,更新后页面显示的是4不是3,但是依然是异步的。
3)setState(updater,calback)
因为setState更新是异步的,如上代码所示,最后页面显示的是4,但是控制台打印出来的结构是1,无法取得更新后的值,如果要取得更新后的值,需要在setState的参数中,再加一个回调函数,回调函数会在DOM更新后执行,所以可以在回调函数中取到更新后的值
add = () => {
this.setState((state)=>{
return {
num:state.num +1
}
});
this.setState((state)=>{
return {
num:state.num +2
}
},()=>{
console.log("更新后的值:"+this.state.num);
});
console.log(this.state.num);
}
执行结果如下:

React 入门学习笔记整理(五)—— state的更多相关文章
- React 入门学习笔记整理目录
React 入门学习笔记整理(一)--搭建环境 React 入门学习笔记整理(二)-- JSX简介与语法 React 入门学习笔记整理(三)-- 组件 React 入门学习笔记整理(四)-- 事件 R ...
- React 入门学习笔记整理(六)—— 组件通信
1.父子组件通信 1)父组件与子组件通信,使用Props 父组件将name传递给子组件 <GreateH name="kitty"/> 子组件通过props接收父组件的 ...
- React 入门学习笔记整理(七)—— 生命周期
(1)react 生命周期 只有类组件有生命周期,函数组件没有生命周期 1.挂载阶段:这些方法会在组件实例被创建和插入DOM中时被调用: 1)constructor(props) 初始化组件的状态.绑 ...
- React 入门学习笔记整理(八)—— todoList
APP.js import React, { Component,createRef,Fragment} from 'react'; import Todos from './components/t ...
- React 入门学习笔记整理(一)——搭建环境
使用create-react-app脚手架搭建环境 1.安装node .软件下载地址:https://nodejs.org/en/,我下的推荐的版本. 安装之后测试是否安装成功.windows系统下, ...
- React 入门学习笔记整理(二)—— JSX简介与语法
先看下这段代码: import React from 'react'; //最终渲染需要调用ReactDOM库,将jsx渲染都页面中 import ReactDOM from 'react-dom'; ...
- React 入门学习笔记整理(三)—— 组件
1.定义组件 1)函数组件 function GreateH(props){ return <div> <h2>hello,{props.name}</h2> &l ...
- React 入门学习笔记整理(四)—— 事件
1.事件定义 React事件绑定属性的命名采用驼峰式写法,而不是小写. 如果采用 JSX 的语法你需要传入一个函数作为事件处理函数,而不是一个字符串(DOM元素的写法) 在类组件中定义函数,通过thi ...
- React 入门学习笔记整理(九)——路由
(1)安装路由 React-router React-router提供了一些router的核心api,包括Router, Route, Switch等,但是它没有提供dom操作进行跳转的api. Re ...
随机推荐
- 在IIS建立的ftp,可以成功连接登录,但是不显示目录
IIS建立FTP站点很简单,不作说明 Windows的防火墙也开通了FTP端口(默认21),Telnet也是通的,在本机可以打开,在局域网其它电脑或外网也可以连接,但就是不显示目录,如果用浏览器打开提 ...
- /etc/sysconfig/iptables 默认配置详解
[参考链接]:一把三尺剑的百度知道回答 1. iptables文件 2. 规则语句详解 :INPUT ACCEPT [0:0] # 该规则表示INPUT表默认策略是ACCEPT :FORWARD AC ...
- Typescript 学习笔记四:回忆ES5 中的类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- python中stack在实际中的简单应用之平衡符号
很多书籍都在讲stack的概念和使用方法,等我们把概念熟悉后,发现不知道在什么场景下使用 该结构体,这里就列几个实用的例子,让大家了解一下stack在实际中的用处和厉害之处. 由于stack中的特点是 ...
- python(leetcode)-350两个数组的交集
给定两个数组,编写一个函数来计算它们的交集. 示例 1: 输入: nums1 = [1,2,2,1], nums2 = [2,2] 输出: [2,2] 示例 2: 输入: nums1 = [4,9,5 ...
- 配置redis
配置Redis 配置相关redis.conf bind 127.0.0.1 注释掉 否则其它远程计算机无 ...
- java中的字符、字符串及数字之间的转换(转)
一.string 和int之间的转换 1.string转换成int :Integer.valueOf("12") 2.int转换成string : String.valueOf( ...
- 在Ubuntu中搭建KMS服务器
介绍 基于vlmcsd搭建的KMS服务器. 根据github上的说明,这个工具是用C写的,没有任何依赖,可以直接运行.而且它横跨几乎现在所有的系统平台,如Android, FreeBSD, Solar ...
- oracle笔记--查询10条之后记录的数据
本文版权归 远方的风lyh和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 由于之前一直在用mysql 对于oracle 的一些语法不太了解,自己有一次去面试让写一个oracle ...
- 动态生成二维码并利用canvas合成出一张图片(类似海报、分享页)
在前端开发并打算推广一个APP的时候,推广页是免不了的,而推广页的展示方式一般是给人家一个二维码,让别人自己去安装APP,这样前段任务也达到了,这次写这篇文章的原因主要还是总结一下,其中有很多不完善的 ...