亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

日志輸出與展示效果有差異

class?CommentArea?extends?React.Component{

????constructor(props)
????{
????????super(props)
????????this.state?=
????????????{
????????????????comments:[]
????????????}

????????this.handleComment=this.handleComment.bind(this)
????????this.onDelete=this.onDelete.bind(this)
????}

????handleComment(value)
????{
????????this.setState({
????????????comments:[...this.state.comments,value]
????????})
????}

????onDelete(deleteIndex)
????{
????????console.log(this.state.comments)

????????console.log(deleteIndex)

????????this.setState({
????????????comments:?this.state.comments.filter((item,index)?=>?{return?index?!=?deleteIndex})
????????})

????????console.log(this.state.comments)
????}

????render()?{
????????const?comments?=?this.state.comments
????????return(
????????????<div>
????????????????<CommentList?comments={comments}?onDelete={this.onDelete}></CommentList>
????????????????<CommentBox2?commentsLength={comments.length}?onHandleComment={this.handleComment?}></CommentBox2>

????????????</div>
????????)
????}

}

export?default?CommentArea

點擊刪除留言時,界面已經刪除相應留言,但是對于state里comments數組元素的日志輸出始終慢一個節拍。


原始效果

https://img1.sycdn.imooc.com//5d56c7170001cae612341800.png

  1. 點擊刪除2?界面及后日志輸出

    https://img1.sycdn.imooc.com//5d56c79f0001a18412501736.png

  2. 點擊刪除3?界面及后日志輸出

    https://img1.sycdn.imooc.com//5d56c7e9000141ba12281894.png

正在回答

1 回答

因為 this.setState 方法是異步的,可以參考這篇文章?https://segmentfault.com/a/1190000013040438?utm_source=tag-newest

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

日志輸出與展示效果有差異

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號