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

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

react從state中獲取的數組可以直接修改嗎?

react從state中獲取的數組可以直接修改嗎?

慕容森 2018-11-13 12:40:46
如下代碼感覺不合理,應該怎么寫var items = this.state.items;   items[i].status = 'doing';   this.setState({         items: items   });問題出現的環境背景及自己嘗試過哪些方法相關代碼// 請把代碼文本粘貼到下方(請勿用圖片代替代碼)你期待的結果是什么?實際看到的錯誤信息又是什么?
查看完整描述

1 回答

?
慕碼人2483693

TA貢獻1860條經驗 獲得超9個贊

首先不推薦這種寫法,更為推薦的是immutable的寫法,比如:

var items = this.state.items;  

this.setState({  
  items: items.map(item => ({...item, ...{status: 'doing'}}))  
});

為什么直接修改不推薦呢?

有兩個原因:

1 . 性能問題

這種直接改變原有對象的方式導致react無法對其進行任何優化,因此
會有潛在的性能問題

2 . 很難定位問題

如果你用了purecomponent, 會發現狀態無法直接更新。
原因在于purecomponent重寫了SCU,SCU中通過直接判斷state和props前后的引用差別來判斷,因此會
返回false,導致render無法運行


查看完整回答
反對 回復 2018-11-13
  • 1 回答
  • 0 關注
  • 2186 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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