setState的新版用法

1.新版本的react更新了setState的用法,可以使用箭头函数赋值,效率更高。

				<div>
					<label htmlFor="insertArea">输入内容</label>
					<input 
						id="insertArea"
						className='input'
						value={this.state.inputValue}
						onChange={this.handleInputChange}
						ref={(input) => {this.input = input}}
					/>
					<button onClick={this.handleBtnClick}>提交</button>
				</div>

比如这段代码 ,使用setState方法去给list inputValue赋值,setState提供两个参数,都可以是箭头函数,第一个参数是给state赋值,第二个参数是异步方法完成之后,做的事情,也就是赋值完成之后做什么,这里我们打印一下list的数据个数,如果不写在第二个参数中,打印的个数会少一个,因为setState是异步方法

	handleBtnClick() {
		this.setState((prevState) => ({
			list: [...prevState.list, prevState.inputValue],
			inputValue: ''
		}), () => {
			console.log(this.ul.querySelectorAll('div').length);
		});
	}

2.箭头函数中会提供一个prevState,这个参数代表当前state中的值,未改变的state的值。所以可以替代下面这种写法

	handleBtnClick() {
		this.setState((prevState) => ({
			list: [...this.state.list,this.state.inputValue],
			inputValue: ''
		}), () => {
			console.log(this.ul.querySelectorAll('div').length);
		});
	}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值