使用React-Native在Android上收听传入链接

htt*_*ick 3 android deep-linking react-native

我能够使用链接库侦听和处理IOS上的传入链接:https://facebook.github.io/react-native/docs/linking.html,但它显示了添加事件监听器的功能对于网址是IOS平台特定的.有没有其他方法可以在Android上监听我的应用程序的传入链接并在Javascript端处理它?

ant*_*129 6

我刚刚开始工作!您只需按照这些说明操作即可.

基本上,<intent-filter>在你现有的一个下添加一个android/app/src/main/AndroidManifest.xml,包含VIEW动作,DEFAULTBROWSABLE类别,至少一个<data>.

然后只需重建并重新安装你的APK(react-native run-android),就是这样!<data>现在,您的应用中会打开与您的代码匹配的链接!

现在只需在您的主Javascript类中使用Linking.getInitialURL()捕获此URL componentDidMount()!

清单示例:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="net.yourapp"
  android:versionCode="1"
  android:versionName="0.1">

  <uses-permission android:name="android.permission.INTERNET" />
  <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>

  <uses-sdk
    android:minSdkVersion="16"
    android:targetSdkVersion="22" />

  <application
    android:name=".MainApplication"
    android:allowBackup="true"
    android:label="@string/app_name"
    android:largeHeap="true"
    android:icon="@mipmap/ic_launcher"
    android:theme="@style/AppTheme">

    <activity
      android:name=".MainActivity"
      android:label="@string/app_name"
      android:screenOrientation="portrait"
      android:configChanges="keyboard|keyboardHidden|screenSize">
      <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category android:name="android.intent.category.LAUNCHER" />
      </intent-filter>

      <!-- HERE: -->
      <intent-filter>
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />
        <data android:scheme="https" android:host="yoursite.net" />
        <data android:scheme="https" android:host="yoursite.com" />
        <data android:scheme="https" android:host="yoursite" />
        <data android:scheme="customscheme" android:host="yourpath" />
      </intent-filter>

    </activity>
    <activity android:name="com.facebook.react.devsupport.DevSettingsActivity" />
  </application>

</manifest>
Run Code Online (Sandbox Code Playgroud)