Linking
gives you a general interface to interact with both incoming
and outgoing app links.
If your app was launched from an external url registered to your app you can access and handle it from any component you want with
NOTE: For instructions on how to add support for deep linking on Android, refer to Enabling Deep Links for App Content - Add Intent Filters for Your Deep Links.
If you wish to receive the intent in an existing instance of MainActivity,
you may set the launchMode
of MainActivity to singleTask
in
AndroidManifest.xml
. See <activity>
documentation for more information.
NOTE: On iOS you'll need to link RCTLinking
to your project by following
the steps described here.
In case you also want to listen to incoming app links during your app's
execution you'll need to add the following lines to you *AppDelegate.m
:
And then on your React component you'll be able to listen to the events on
Linking
as follows
To start the corresponding activity for a link (web URL, email, contact etc.), call
If you want to check if any installed app can handle a given URL beforehand you can call
Add a handler to Linking changes by listening to the url
event type
and providing the handler
Remove a handler by passing the url
event type and the handler
Try to open the given url
with any of the installed apps.
You can use other URLs, like a location (e.g. "geo:37.484847,-122.148386"), a contact, or any other URL that can be opened with the installed apps.
NOTE: This method will fail if the system doesn't know how to open the specified URL. If you're passing in a non-http(s) URL, it's best to check {@code canOpenURL} first.
NOTE: For web URLs, the protocol ("http://", "https://") must be set accordingly!
Determine whether or not an installed app can handle a given URL.
NOTE: For web URLs, the protocol ("http://", "https://") must be set accordingly!
NOTE: As of iOS 9, your app needs to provide the LSApplicationQueriesSchemes
key
inside Info.plist
or canOpenURL will always return false.
@param URL the URL to open
If the app launch was triggered by an app link,
it will give the link url, otherwise it will give null
NOTE: To support deep linking on Android, refer http://developer.android.com/training/app-indexing/deep-linking.html#handling-intents
You can edit the content above on GitHub and send us a pull request!
Examples # | Edit on GitHub |