スマートフォンアプリ制作 ~React Native with Expo~ 環境構築
はじめに
ReactNativeでスマートフォンアプリを開発してみて色々感じたことやハマったことが沢山あったので、共有してみたいと思い記事を作成しました。
当方はアプリ開発やJavaSctiptに関しては初心者の部類に入るかと思いますので、ご了承のほどをよろしくお願いします。
また、プロジェクトの作成から実際のリリースまでの過程をご紹介させて頂きます。
注意
React Native 関連の技術は頻繁に更新されていますので、参考にならない部分もあります。
環境構築
- mac
- npm (v6.4.1)
- nvm (v0.33.8)
- node (v8.12.0)
- expo (v2.2.4)
nvmの導入
ReactNativeはnpmで各種ライブラリを管理します。
バージョンごとに管理したいので nvm を導入することをお勧めします。
引用元: nvm
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.8/install.sh | bash
HOME/.nvm にパスを通します
お使いのシェルのプロファイルに以下を追加します
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"
nvm --version
0.33.8
これでnvmが利用可能になりました。
npmの導入
nvmにて安定したバージョンをインストールします
nvm install --lts
......
#Now using node v8.12.0 (npm v6.4.1)
一覧表示
nvm ls
-> v8.12.0
system
シェルが再起動するとsystemに戻るためエイリアスを指定して切り替えるのがオススメです。
nvm alias react-native v8.12.0
nvm use react-native
#Now using node v8.12.0 (npm v6.4.1)
Expo の導入
公式ドキュメント: expo
Expo とは環境構築を自動で行い、ストアに出すまでの工数を大幅に省略してくれるフレームワークです。手元の実機テストも簡単に行えます。XCodeを触りたくない人向け。
デメリットはネイティブ(通知, Wifiモジュールなど)関連の操作がExpoが提供しているAPIに限定されること。アプリの種類によっては相入れない場合があるので、Expoのドキュメントを確認してからの選択をおすすめします。
npmからインストール
npm install expo-cli --global
# + [email protected]
expo --version
# 2.2.4
プロジェクトを作成したいディレクトリで init します
blankかtabsを選択します。最初はblankで。
expo init your-project-name
# ? Choose a template:
❯ blank
# The Blank project template includes the minimum dependencies to run and an empty root component.
tabs
# The Tab Navigation project template includes several example screens.
init が終了後、プロジェクト名のディレクトリが生成されています。
移動して起動します。
cd your-project-name
expo start
QRコードが表示されれば起動成功です。
キーボードの i キーでiOSシミュレータが立ち上がり、初期画面が表示されます。
内容は App.js から読み込まれます。
環境構築はここまでです。色々試してみてください。
have a happy coding!
Author And Source
この問題について(スマートフォンアプリ制作 ~React Native with Expo~ 環境構築), 我々は、より多くの情報をここで見つけました https://qiita.com/ototonari/items/88822f833e65c7960382著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .