はじめに 去年(2018)春ごろから、Firebase x React x TypeScriptでアプリケーションを作成する機会が多くなり、 自分の中である程度書き方が固まってきたので、その内容をまとめることにしました。 フロントエンドの実装を想定した説明をしますが、サーバーサイドも似たような構造で筆者は書きます。 Firebase、TypeScriptを使ったことがないかたは、少し難しいかもしれません。 「俺はこのような書き方してるよ〜」などあれば、コメントで教えて欲しいです! アーキテクチャについて 筆者はFirebaseプロジェクトでの設計では、レポジトリパターンを使って設計することが多いです。 ※厳密にレポジトリパターンになっているかといわれると、なっていないかも... 下記がフォルダ構造です。
![1年ほどFirebase x TypeScriptで開発してきて定まってきた僕なりの書き方 - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/555b8a7513010681986385eedd69c7ffc7229687/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Fadvent-calendar-ogp-background-7940cd1c8db80a7ec40711d90f43539e.jpg%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTk3MiZoPTM3OCZ0eHQ9MSVFNSVCOSVCNCVFMyU4MSVCQiVFMyU4MSVBOUZpcmViYXNlJTIweCUyMFR5cGVTY3JpcHQlRTMlODElQTclRTklOTYlOEIlRTclOTklQkElRTMlODElOTclRTMlODElQTYlRTMlODElOEQlRTMlODElQTYlRTUlQUUlOUElRTMlODElQkUlRTMlODElQTMlRTMlODElQTYlRTMlODElOEQlRTMlODElOUYlRTUlODMlOTUlRTMlODElQUElRTMlODIlOEElRTMlODElQUUlRTYlOUIlQjglRTMlODElOEQlRTYlOTYlQjkmdHh0LWFsaWduPWxlZnQlMkN0b3AmdHh0LWNvbG9yPSUyMzNBM0MzQyZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZzPTUxOTQyNjMwZDk3YjM5ZjFjMDM5MzBjZTU5ZWZhOTg1%26mark-x%3D120%26mark-y%3D96%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZoPTc2Jnc9OTcyJnR4dD0lNDBrb3VzYWt1LW1hcm9uJnR4dC1jb2xvcj0lMjMzQTNDM0MmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz03OGFiNmFhYTZmMzlkODI2OWMwN2U3NDEwZDdlN2QzZg%26blend-x%3D120%26blend-y%3D500%26blend-mode%3Dnormal%26s%3D09deaeeb11e22b58745f99e15d7f61e9)