![](https://cdn-ak-scissors.b.st-hatena.com/image/square/e7ed81b0c337f3416a2d34fca7d421629ad3731f/height=288;version=1;width=512/https%3A%2F%2Fres.cloudinary.com%2Fzenn%2Fimage%2Fupload%2Fs--qJ_qqAxl--%2Fc_fit%252Cg_north_west%252Cl_text%3Anotosansjp-medium.otf_55%3Areact%252520%25252B%252520typescript%2525E3%252581%2525A7loading%2525E3%252582%252592%2525E3%252581%252584%2525E3%252581%252584%2525E6%252584%25259F%2525E3%252581%252598%2525E3%252581%2525AB%2525E6%252589%2525B1%2525E3%252581%252586hooks%2525E3%252582%252592%2525E4%2525BD%25259C%2525E3%252581%2525A3%2525E3%252581%25259F%252Cw_1010%252Cx_90%252Cy_100%2Fg_south_west%252Cl_text%3Anotosansjp-medium.otf_37%3A%2525E3%252581%2525A1%2525E3%252581%2525B3%2525E3%252581%2525AF%2525E3%252582%252580%252Cx_203%252Cy_121%2Fg_south_west%252Ch_90%252Cl_fetch%3AaHR0cHM6Ly9saDMuZ29vZ2xldXNlcmNvbnRlbnQuY29tL2EvQUFjSFR0ZF9UcllnZW1raWhJVWhlMWwteXZYOWdfc1BVUDlOUjVxRk56bV89czk2LWM%3D%252Cr_max%252Cw_90%252Cx_87%252Cy_95%2Fv1627283836%2Fdefault%2Fog-base-w1200-v2.png)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
react + typescriptでloadingをいい感じに扱うhooksを作った
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
react + typescriptでloadingをいい感じに扱うhooksを作った
react + typescript において data fetch や reload を行う際に、loading 中は placeholder などを表示... react + typescript において data fetch や reload を行う際に、loading 中は placeholder などを表示し、loading が終わったらデータを表示する、というようなことはよくやると思いますが、その際に loading の true/false と、fetch したデータが取得できているか(undefined でないかどうか)を両方チェックしていると、コードが冗長になりがちです。 ということで、これをいい感じに扱える hooks を作成しました。 なお Suspence は利用しない時代の話です。 作成した hooks import { useState, useCallback } from "react"; export const useWithLoading = <P extends unknown[], R>( fn: (...