0

如何在 React Navigation 的嵌套导航器中实现深度链接。这里我有一个嵌套的堆栈导航器:

function AuthStack() {
  return (
    <Stack.Navigator>
        <Stack.Screen component={Login} name="Login" />  // deep link this screen
        <Stack.Screen component={ResetPassword} name="ResetPassword" />
    </Stack.Navigator>
  );
}

它嵌套在另一个主堆栈导航器中:

const linking = {
  prefixes: ["wagal://"],
  config: {
    screens: {
      AuthStack: "login",  // this doesn't reference `Login` screen on deep linking
    },
  },
};

function homeStack() {
  return (
    <NavigationContainer linking={linking}>
      <Stack.Navigator>
        <Stack.Screen component={AuthStack} name="AuthStack" />  // here
        // ...
      </Stack.Navigator>
    </NavigationContainer>
  );
}

我试图通过深层链接“wagal://login/”进行Login筛选:

screens: {
  AuthStack: "login",
},

但它没有用,我也尝试过:

screens: {
  Login: "login",
},

他们不工作,我在文档中也找不到任何东西。我该如何解决这个问题?谢谢你。

4

1 回答 1

2

尝试将其作为嵌套导航器处理。

AuthStack是父名。
Login是路线名称。
login是网址路径。

const config = {
  screens: {
    AuthStack: {
      screens: {
        Login: 'login',
      },
    }
  }
};
于 2021-09-10T18:25:16.993 回答