![](https://cdn-ak-scissors.b.st-hatena.com/image/square/991921d86dcef7f7a9bf8d7c4322f3fc6905254b/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-412672c5f0600ab9a64263b751f1bc81.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk3MiZoPTM3OCZ0eHQ9JUUzJTgwJTkwUmVhY3QlRTMlODAlOTElRTMlODMlODclRTMlODMlOTUlRTMlODIlQTklRTMlODMlQUIlRTMlODMlODglRTUlODAlQTQlRTMlODIlODJ1bmRlZmluZWQlRTMlODMlODElRTMlODIlQTclRTMlODMlODMlRTMlODIlQUYlRTMlODIlODIlRTMlODElODQlRTMlODIlODklRTMlODElQUElRTMlODElODRjcmVhdGVDb250ZXh0JUUzJTgwJTkwVHlwZXNjcmlwdCVFMyU4MCU5MSZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnM9OTY1YjNlMjA4YTExNWQwMWIwZjNjOTg5YWE5MWNiNTI%26mark-x%3D142%26mark-y%3D57%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZoPTc2Jnc9NzcwJnR4dD0lNDBqb2hubWFja2F5MTUwJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz0zYWMyNjkzYTMxNDE1Njk1MDZiZmQ0OTQyZGNjZTQ2Mg%26blend-x%3D142%26blend-y%3D436%26blend-mode%3Dnormal%26txt64%3DaW4g5qCq5byP5Lya56S-QWNvbXBhbnk%26txt-width%3D770%26txt-clip%3Dend%252Cellipsis%26txt-color%3D%2523212121%26txt-font%3DHiragino%2520Sans%2520W6%26txt-size%3D36%26txt-x%3D156%26txt-y%3D536%26s%3Ddd8800146d6d5a26c0fad83b64f32029)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
【React】デフォルト値もundefinedチェックもいらないcreateContext【Typescript】 - Qiita
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
【React】デフォルト値もundefinedチェックもいらないcreateContext【Typescript】 - Qiita
createContextのデフォルト値としてundefinedを指定したことで、Contextを使用する際にその値がundefine... createContextのデフォルト値としてundefinedを指定したことで、Contextを使用する際にその値がundefinedでないかを”全ての場所で”逐一確認する必要があります。 根本的に、undefinedはアプリケーションにとって何の意味もなさない値です。 それを、わざわざ確認しなければいけないということは、バグやエラーの温床になります。 Solution デフォルト値をundefinedとせず、未定義チェックを行えるcretaeContextのwrapperを作成して解決します。 function createCtx<ContextType>() { const ctx = React.createContext<ContextType | undefined>(undefined); function useCtx() { const c = React.useCont