概要
このブログではリアクトネイティブ(React Native)だけの問題ではなく、Reactで開発する時、問題を解決してみようかと思います。Reactで開発する時、プロジェクトの構造を綺麗にしてもimport
する時、長くなる../../../
フォルダの参照問題は解決できないです。このブログでは長くなるこのフォルダの参照問題を少しでも解決してみようかと思って作成しました。リアクトネイティブ(React Native)の開発者だけではなくReactJS開発者にも参考になると嬉しいです。
フォルダの構造
私はリアクトネイティブ(React Native)で開発する時、下記のようなフォルダ構造を使っています。
|-- android/
|-- ios/
|-- src/
| |-- @types/
| |-- Assets/
| | |-- Images/
| |-- Component/
| | |-- BannerContainer/
| | | |-- index.tsx
| | |-- LoadingContainer/
| | | |-- index.tsx
| |-- Screen/
| | |-- Home/
| | | |-- SomeContainer/
| | | | |-- index.tsx
| | | |-- SomeContainer2/
| | | | |-- SomeContainerItem/
| | | | | |-- index.tsx
| | | | |-- index.tsx
| | | |-- index.tsx
| |-- Util/
|-- index.js
最初はComponent
、Container
、Screen
で分けって開発しましたが、Container
が特定なScreen
に従属的に使えって、色んなScreen
で使う場合が少なかったです。それで色んなScreen
で共通的使う部分をComponent
に入れって、従属的なContainer(Component)はScreenフォルダの下に置いています。もちろん、Component
の下にもComponent(Container)に従属してるComponentが存在しています。
このようにした理由は二つぐらいあります。一つはScreen
に従属されてるContainer
を探すため、Container
フォルダまで探して、またComponent
フォルダまで探さなきゃならない不便さがありました。今は従属されてるContainerはScreenフォルダ下にあるので探す時、楽になりました。もう一つはコピペーを楽にするためです。一人で臭味で色んなアプリを開発してるので一つのプロジェクトで作ったComponentをコピーして他のプロジェクトにペーストする場合があります。Container
フォルダを別で管理する時、Screen
をコピーするようになったら、Screenをコピーしてそこに必要なContainerをコピーしてComponentもコピーする必要がありました。今はScreen一つだけコピーすればContainerが一緒にコピーされるのでコピペーがちょっと楽になりました。このような不便さを解決するため上のようなプロジェクトの構造を持てるようになりました。参考ですがReactJSは下記のよなフォルダ構造を使っています。
|-- android/
|-- ios/
|-- src/
| |-- @types/
| |-- Assets/
| | |-- Images/
| |-- Component/
| | |-- BannerContainer/
| | | |-- index.tsx
| | |-- LoadingContainer/
| | | |-- index.tsx
| |-- Feature/
| | |-- Login/
| | | |-- SomeContainer/
| | | | |-- index.tsx
| | | |-- SomeContainer2/
| | | | |-- SomeContainerItem/
| | | | | |-- index.tsx
| | | | |-- index.tsx
| | | |-- index.tsx
| |-- Util/
|-- index.js
上のようにScreen
で管理してるフォルダをFeature
の名前のフォルダで管理しています。皆さんはどんなフォルダ構造を使っていますか?色んな人たちが参考できるように一番下のコメントに皆さんのフォルダ構造を共有してみてください!(私も参考したいですT^T)
問題
私はこの問題を解決するためbabel-plugin-root-import
とTypeScript
の設定でrootフォルダから参照出来るように修正しました。
例えば、既存には下記のようにimport
をしていましたが、
import { BannerContainer } from '../../../Component/BannerContainer'
現在は下記のように使うことができるようになりました。
import { BannerContainer } from '~/Component/BannerContainer'
このように使えうるようにするため、babel-plugin-root-import
とTypeScript
の設定をしてみましょう。
解決策
私はこの問題を解決するためbabel-plugin-root-import
とTypeScript
の設定でrootフォルダから参照出来るように修正しました。例えば、../../../Component/BannerContainer
の部分が~/Component/BannerContainer
ように参照できます。下記で設定する方法について説明します。
babel-plugin-root-import
rootフォルダから参照出来るようにするためbabel-plugin-root-import
を下記のコマンドでインストールします。
npm install babel-plugin-root-import --save-dev
リアクトネイティブ(React Native)プロジェクトのbabel.config.js
を開いて下記のように修正します。
module.exports = {
presets: ['module:metro-react-native-babel-preset'],
plugins: [
...,
[
'babel-plugin-root-import',
{
rootPathPrefix: '~',
rootPathSuffix: 'src',
},
],
],
};
私のフォルダの構造を見れば分かると思いますが、私は全てのソースをsrc
に入れって管理しています。したがって、私はroot
フォルダではなくsrc
フォルダを基準にして動作するように設定しました。
TypeScript
TypeScriptを使ってない方は上の設定だけで大丈夫です。私はリアクトネイティブ(React Native)プロジェクトでTypeScriptを使って流のでTypeScriptがrootフォルダを認識するように設定する必要があります。リアクトネイティブ(React Native)にTypeScriptを提供する方法は下記のブログを参考してください。
リアクトネイティブ(React Native)プロジェクトのtsconfig.json
ファイルを開いて下記のように修正します。
{
"compilerOptions": {
...
"baseUrl": "./src", // all paths are relative to the baseUrl
"paths": {
"~/*": ["*"] // resolve any `~/foo/bar` to `<baseUrl>/foo/bar`
}
},
...
}
完了
これでリアクトネイティブ(React Native)プロジェクトでimport
する時、長かった../../../../
とはバイバイしました。もっとプロジェクトが綺麗に管理出来るように見えて嬉しいです。皆さんも遅くなる前この部分を追加することをお勧めします!
私のブログが役に立ちましたか?下にコメントを残してください。それは私にとって大きな大きな力になります!
アプリ広報
Deku
が開発したアプリを使ってみてください。Deku
が開発したアプリはFlutterで開発されています。興味がある方はアプリをダウンロードしてアプリを使ってくれると本当に助かります。