![](https://cdn-ak-scissors.b.st-hatena.com/image/square/1d90fbe48f04db9966a8d68026d3b5d28529085e/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-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk3MiZoPTM3OCZ0eHQ9VHlwZVNjcmlwdCVFMyU4MSVBNyUyMFJlZHV4JTIwJUUzJTgxJUFFJTIwUmVkdWNlciVFOSU4MyVBOCVFNSU4OCU4NiVFMyU4MiU5MiVFNSU5RSU4QiVFNSVBRSU4OSVFNSU4NSVBOCVFMyU4MSU4QiVFMyU4MSVBNCVFMyU4MiVCOSVFMyU4MyU4MyVFMyU4MiVBRCVFMyU4MyVBQSVFNiU5QiVCOCVFMyU4MSU4RiZ0eHQtYWxpZ249bGVmdCUyQ3RvcCZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnM9ZTY1MzdlZDdmMzE2Yjg1MDg1ZDkwZjY2Y2E0NTdhMzg%26mark-x%3D142%26mark-y%3D57%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZoPTc2Jnc9NzcwJnR4dD0lNDB0YXFtJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz1lZWQ2ZmM0YThjMWIyYzBjZTA4NjI3OWE3ZGE5M2UwZg%26blend-x%3D142%26blend-y%3D486%26blend-mode%3Dnormal%26s%3Dfb1d8fa020ce10b6d871c0cd2d138917)
エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
TypeScriptで Redux の Reducer部分を型安全かつスッキリ書く - Qiita
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
TypeScriptで Redux の Reducer部分を型安全かつスッキリ書く - Qiita
はじめに TypeScript 2.8がリリースされ色々な機能が追加されました。 その中でもConditional types、特... はじめに TypeScript 2.8がリリースされ色々な機能が追加されました。 その中でもConditional types、特にReturnTypeがなかなか優秀で 今まで諦めていた部分がきれいに書けるようになっております。 そこで個人的にずさんになりがちな、ReduxのReducer周りを少し改良してみたのでご紹介 コード const INCREMENT = 'app/example/INCREMENT' as const; const SET_COUNT = 'app/example/SET_COUNT' as const; export const increment = () => ({ type: INCREMENT, }); export const setCount = (num: number) => ({ type: SET_COUNT, payload: { cou