前提・実現したいこと
setStateで書いている箇所をuseStateを使った書き方に変えたいと思っています。
前回の質問で、stateの変化後にuseEffectで捕まえればいいというのは分かったのですが、コールバック関数がresolveの場合の書き方がわかりません。(console.logなどはそのままuseEffectに書けばいいと思います。)
調べてみても同じことをやっている人が見当たらなくて困っています。
わかる方がいましたら、コメントお願いします。
発生している問題・エラーメッセージ
setStateのコールバック関数でpromiseのresolveを返す時のuseEffectへの書き換えがわからない
該当のソースコード
Javascript
1//書き換え前 2function HandleUpdateBeforeSortStart = ({index}) => { 3 return new Promise((resolve) => 4 this.setState( 5 ({items}) => ({ 6 sortingItemKey: items[index], 7 isSorting: true, 8 }), 9 resolve, 10 ), 11 ); 12 }; 13 14//書き換え後 15function HandleUpdateBeforeSortStart(info, category) { 16 //省略 17 18 useEffect(() => {}, [sortingItemKey, isSorting]); 19 20 return new Promise((resolve) => { 21 setSortingItemKey(items[index]); 22 setIsSorting(true); 23 // resolve(); 24 }); 25 }
あなたの回答
tips
プレビュー