javascript - 如何在 react-native 中结合使用 Drawer Navigator 和 Stack Navigator?

标签 javascript android react-native

使用的包:

  1. "@react-navigation/drawer": "^6.1.8",
  2. "@react-navigation/native": "^6.0.6",
  3. "@react-navigation/stack": "^6.0.11",

问题:

图片 1,2 & 3: 我已经实现了抽屉,它显示两个选项作为主页和条款和条件。如果您点击 t&c 选项,它会打开它的屏幕,如果您点击主屏幕,它会返回到主页屏幕。

图片 1 和 4:我已将“点击详情页面”文本设为可在主屏幕上点击,点击后应该会转到详情屏幕,但会抛出错误,如图 4 所示,我对如何操作感到困惑实现它。我在哪里编写 Stack.Navigation 代码。

App.js

import * as React from 'react';
import { Button, View } from 'react-native';
import { createDrawerNavigator } from '@react-navigation/drawer';
import { NavigationContainer } from '@react-navigation/native';
import HomeScreen from './Screens/HomeScreen';
import DetailPage from './Screens/DetailPage';
import TermsCondition from './Screens/TermsCondition';


const Drawer = createDrawerNavigator();

export default function App() {
  return (
    <NavigationContainer>
      <Drawer.Navigator initialRouteName="HomeScreen">
        <Drawer.Screen name="HomeScreen" component={HomeScreen} />
        <Drawer.Screen name="Term&Condition" component={TermsCondition} />
      </Drawer.Navigator>
    </NavigationContainer>
  );
}

HomeScreen.js

export default function HomeScreen({ navigation }) {
    return (
        <TouchableOpacity onPress={() => navigation.navigate('DetailPage')}>
            <View style={{ flexDirection: 'row' }}>
                <Text style={{ fontSize: 50 }}>Click for Details Page</Text>
            </View>
        </TouchableOpacity>
    );
}

条款条件.js

function TermsCondition({ navigation}) {
    return (
      <View style={{ flexDirection: 'row' }}>
        <Text style={{fontSize:50}}>T&C Page</Text>
      </View>
    );
  }
  export default TermsCondition;

DetailPage.js

function DetailPage({ navigation}) {
    return (
      <View style={{ flexDirection: 'row' }}>
        <Text style={{fontSize:50}}>DetailPage</Text>
      </View>
    );
  }

导出默认的DetailPage; 很抱歉这个愚蠢的问题,但我在网上试过但很困惑。 提前谢谢您!

最佳答案

这是Nested Navigation的简单步骤 这是相同的解决方案:

App.js

import * as React from 'react';
import { Button, View } from 'react-native';
import { createDrawerNavigator } from '@react-navigation/drawer';
import { NavigationContainer } from '@react-navigation/native';
import HomeScreen from './Screens/HomeScreen';
import DetailPage from './Screens/DetailPage';
import TermsCondition from './Screens/TermsCondition';
import { createStackNavigator } from '@react-navigation/stack';



const Drawer = createDrawerNavigator();
const Stack = createStackNavigator();

{/* Add Drawer.Navigation to a function.*/}
function Root() {
  return (
    <Drawer.Navigator>
      <Drawer.Screen name="HomeScreen" component={HomeScreen} />
      <Drawer.Screen name="Term&Condition" component={TermsCondition} />
    </Drawer.Navigator>
  );
}

export default function App() {
  return (
    <NavigationContainer>
      <Stack.Navigator>
        <Stack.Screen options={{
        }} name="Root" component={Root} {/*Call function as Stack.Screen*/}
        options={{ headerShown: false }} /> {/*This will disable function header*/}
        <Stack.Screen options={{
          title: 'DetailPage'
        }} name="DetailPage" component={DetailPage} />
      </Stack.Navigator>

    </NavigationContainer>
  );
}

注意:其余所有DetailPage.js、HomeScreen.js、TermCondition.js的代码都是一样的。

附言。从错误中休息一下,然后以全新的心态返回。这可能会解决它:-)

关于javascript - 如何在 react-native 中结合使用 Drawer Navigator 和 Stack Navigator?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69974336/

相关文章:

android - 如何在 View 寻呼机中一次只加载一页

java - 在 Android 上更改评级栏

firebase - Expo 和 firebase 云功能

android - React-native run-android 在 :app:processDebugResources 上失败

javascript - 在列表框边缘浏览器中选择多个选项 ruby​​ selenium webdriver

javascript - 本地时间到服务器时区的转换

javascript - 如何获取:contains() Selector using an Array with multiple matches in a DIV?的总实例

java - Eclipse Android 应用程序 "PlaceholderFragment cannot be resolved to a type"错误

react-native - 来自 Google Drive 的 React Native [Android] URI w/'React-Native-Document-Picker' & 'react-native-get-real-path'

javascript - 这种通过 Node 发送电子邮件的方式不安全吗?