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

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

js異步list.push和setTimeout,list.splice的時間差問題該怎么解決?

js異步list.push和setTimeout,list.splice的時間差問題該怎么解決?

慕桂英4014372 2019-05-19 14:19:54
list//頁面展示數組cacheList//緩存數組,ajaxsetTimeout((=>{    list.shift();    if(cacheList.length<=8){      this.getData();    }        const arr = this.state.cacheList.splice(0,num);    // 這一步cacheList是[]    //剛好下一步ajax成功了,cacheList.push成功了,結果cacheList應該有長度    //但是被上一步setState 進去了    list.push(...arr);        this.setState({      list,      cacheList    })}),2000)
查看完整描述

2 回答

?
絕地無雙

TA貢獻1946條經驗 獲得超4個贊

把后面的操作也放在ajax的回調里面。


查看完整回答
反對 回復 2019-05-19
?
互換的青春

TA貢獻1797條經驗 獲得超6個贊

不明白題主想要表達的意思是什么, 或許該了解一下js的執行順序, list.push 等等操作和 setTimeout之間是不存在 "時間差" 這個東西的。 setTimeout 和 ajax 都是異步的操作。他們的回調函數是要等當前執行棧里面的任務執行完畢之后才會執行的。建議了解javascript事件循環機制 或許你應該等到在異步執行成功后的回調函數里面去拿到數據之后再做相關操作。


查看完整回答
反對 回復 2019-05-19
  • 2 回答
  • 0 關注
  • 963 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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