Summary: Should help people with less xcode experience. Closes https://github.com/facebook/react-native/pull/9748 Differential Revision: D3819960 Pulled By: mkonicek fbshipit-source-id: 2d73611a5ed7261c95eded2f3e20eeb660527cdc
2.3 KiB
id | title | layout | category | permalink | next | previous |
---|---|---|---|---|---|---|
running-on-device-ios | Running On Device | docs | Guides (iOS) | docs/running-on-device-ios.html | running-on-simulator-ios | linking-libraries-ios |
Running an iOS app on a device requires only an Apple ID and a Mac. This guide covers only React Native specific topics.
Accessing the development server from device
You can iterate quickly on device using the development server. First, ensure that you are on the same Wi-Fi network as your computer.
In Xcode, select your phone as build target and press "Build and run"
Hint
Shake the device to open the developer menu.
Building your app for production
You have built a great app using React Native, and you are now itching to release it in the App Store. The process is the same as any other native iOS app, with some additional considerations to take into account.
Building an app for distribution in the App Store requires using the Release
scheme in Xcode. To do this, go to Project -> Scheme -> Edit Scheme (cmd + <)
, make sure you're in the Run
tab from the side, and set the Build Configuration dropdown to release
.
Apps built for Release
will automatically disable the in-app developer menu, which will prevent your users from inadvertently accessing the menu in production. It will also load the JavaScript locally, so you can put the app on a device and test whilst not connected to the computer.
Once built for release, you'll be able to distribute the app to beta testers and submit the app to the App Store.
App Transport Security
App Transport Security is a security feature, added in iOS 9, that rejects all HTTP requests that are not sent over HTTPS. This can result in HTTP traffic being blocked, including the developer React Native server.
ATS is disabled by default in projects generated using the React Native CLI in order to make development easier. You should re-enable ATS prior to building your app for production by removing the NSAllowsArbitraryLoads
entry from your Info.plist
file in the ios/
folder.
To learn more about how to configure ATS on your own Xcode projects, see this post on ATS.