React:生命周期(新)

 

1.新版去掉了原来的componentWillMount,componentWillUpdate,componentWillReceiveProps

2.新增函数      getDerivedStateFromProps

  • 控制state的值在任何时候都取决于props

  • 返回值为nullstate对象,不能为undefined

  • 原型对象自身静态函数,使用前要加static

static getDerivedStateFromProps(props,state){
				console.log('getDerivedStateFromProps',props,state);
				return props
			}

3.新增函数       getSnapshotBeforeUpdate

  • 可接收更新前propsstate,并传递给componentDidUpdate
  • 返回值为null某个值,不能为undefined
  • 返回值传递给componentDidUpdate
class NewsList extends React.Component{

			state = {newsArr:[]}

			componentDidMount(){
				setInterval(() => {
					//获取原状态
					const {newsArr} = this.state
					//模拟一条新闻
					const news = '新闻'+ (newsArr.length+1)
					//更新状态
					this.setState({newsArr:[news,...newsArr]})
				}, 1000);
			}

			getSnapshotBeforeUpdate(){
				return this.refs.list.scrollHeight
			}

			componentDidUpdate(preProps,preState,height){
				this.refs.list.scrollTop += this.refs.list.scrollHeight - height
			}

			render(){
				return(
					<div className="list" ref="list">
						{
							this.state.newsArr.map((n,index)=>{
								return <div key={index} className="news">{n}</div>
							})
						}
					</div>
				)
			}
		}
		ReactDOM.render(<NewsList/>,document.getElementById('test'))

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值