第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

讓 React 在長(zhǎng)時(shí)間運(yùn)行的任務(wù)之間渲染頁(yè)面

讓 React 在長(zhǎng)時(shí)間運(yùn)行的任務(wù)之間渲染頁(yè)面

我在 Javascript 中有一個(gè)長(zhǎng)期運(yùn)行的任務(wù)。React 應(yīng)該在任務(wù)之間的幾個(gè)點(diǎn)重新渲染組件。但它僅在整個(gè)任務(wù)結(jié)束時(shí)重新渲染。如何讓 React 在所有setState()調(diào)用中重新渲染頁(yè)面?一個(gè)簡(jiǎn)化的例子:setStatePromise = (state) => new Promise(resolve => {    this.setState(state, () => resolve());});longRunningTask = async () => {    await this.setStatePromise({progress: 1}); // not shown to the user    await doMuchWork();    await this.setStatePromise({progress: 2}); // not shown to the user    await doEvenMoreWork();    await this.setStatePromise({progress: 3}); // shown to the user when everything is done};onButtonClick = async () => {    await this.longRunningTask();}這是一個(gè)顯示問題的工作示例:https://codesandbox.io/s/intelligent-cori-31qn5我之前使用的解決方法是:setStatePromise = (state) => new Promise(resolve => {    this.setState(state, () => {        setTimeout(() => resolve(), 1);    });});
查看完整描述

2 回答

?
拉丁的傳說

TA貢獻(xiàn)1789條經(jīng)驗(yàn) 獲得超8個(gè)贊

您沒有在 中返回您的承諾longRunningTask,這是原因之一,但這也行不通。生成器可以解決這個(gè)問題,每次需要時(shí)都會(huì)產(chǎn)生承諾。


查看完整回答
反對(duì) 回復(fù) 2021-09-30
  • 2 回答
  • 0 關(guān)注
  • 268 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)