javascript - react 中各個(gè)聲明周期中異步的執(zhí)行順序
問題描述
componentWillMount(){ setTimeout(()=>{ alert(1); },100) } componentDidMount(){ setTimeout(()=>{ alert(2); },100) }
組件中的2個(gè)生命周期函數(shù)都有異步操作,執(zhí)行順序是嚴(yán)格按照聲明周期的順序,也就是先1后2,還是不確定執(zhí)行順序是根據(jù)插入到消息隊(duì)列里面的先后順序執(zhí)行的?問題可以理解為假設(shè)componentWillMount這個(gè)異步結(jié)果返回時(shí)間很長很長,而componentDidMount這個(gè)異步結(jié)果返回時(shí)間很短,有沒有可能先執(zhí)行componentDidMount里面的回調(diào)結(jié)果,然后在執(zhí)行componentWillMount里面的回調(diào)結(jié)果
問題解答
回答1:簡化問題為:假設(shè)兩個(gè)異步動(dòng)作 A 和 B 觸發(fā)順序已知,那么 A 和 B 中同樣延時(shí)的 setTimeout 是否能保證順序?
答案顯然是不能的。例如當(dāng) A 和 B 之間只有微秒級(jí)延時(shí)時(shí),兩個(gè)設(shè)定了巨大延時(shí)的 setTimeout 就不能保證按照調(diào)用 setTimeout 時(shí)的先后順序觸發(fā)。
不能夠依賴這種脆弱的時(shí)序關(guān)系來保證代碼的執(zhí)行順序。在 Code Review 中如果遇到利用這種關(guān)系來實(shí)現(xiàn)數(shù)據(jù)初始化、異步請(qǐng)求等功能的代碼,答主肯定是會(huì)提出意見的。對(duì)于異步的控制流,可以采用 Promise / yield 等方式來保證執(zhí)行順序,在這里就不贅述了。
相關(guān)文章:
1. windows誤人子弟啊2. php傳對(duì)應(yīng)的id值為什么傳不了啊有木有大神會(huì)的看我下方截圖3. python - linux 下用wsgifunc 運(yùn)行web.py該如何修改代碼4. python - oslo_config5. 關(guān)于mysql聯(lián)合查詢一對(duì)多的顯示結(jié)果問題6. 實(shí)現(xiàn)bing搜索工具urlAPI提交7. 冒昧問一下,我這php代碼哪里出錯(cuò)了???8. mysql優(yōu)化 - MySQL如何為配置表建立索引?9. MySQL主鍵沖突時(shí)的更新操作和替換操作在功能上有什么差別(如圖)10. 數(shù)據(jù)庫 - Mysql的存儲(chǔ)過程真的是個(gè)坑!求助下面的存儲(chǔ)過程哪里錯(cuò)啦,實(shí)在是找不到哪里的問題了。
