参考错误:找不到变量:导航

IT技术 javascript reactjs react-native
2021-05-27 14:15:00

所以我想要做的是,我希望通过选择左上角的图标来访问 DrawerNavigator。我为此使用了 react nav 5。我不断收到上面显示的错误。

我试过使用this.props.navigation这样做,但这似乎也不起作用。帮助将不胜感激

应用导航器:

/* eslint-disable no-unused-expressions */
import React, { useState, useEffect } from 'react'
import { NavigationContainer, DrawerActions } from '@react-navigation/native'
import { createStackNavigator } from '@react-navigation/stack'
import auth from '@react-native-firebase/auth'
import {IconButton} from 'react-native-paper'


import Login from '../components/login'
import Signup from '../components/signup'
import forgotPassword from '../components/forgotPassword'
import DashboardScreen from '../screens/DashboardScreen'





const Stack = createStackNavigator()

export default function MyStack() {
  // Set state while Firebase Connects
  const [starting, setStarting] = useState(true)
  const [user, setUser] = useState()

  // Handle state changes for user
  function onAuthStateChanged(user) {
    setUser(user)
    if (starting) setStarting(false)
  }


  useEffect(() => {
    const subcriber = auth().onAuthStateChanged(onAuthStateChanged)
    return subcriber
    // unsub on mount
  }, [])

  if (starting) return null
  
  
  if (!user) {

    return (
      <NavigationContainer>
        <Stack.Navigator
          screenOptions={{
            headerTitleAlign: 'center',
            headerStyle: {
              backgroundColor: '#3740FE',
            },
            headerTintColor: '#fff',
            headerTitleStyle: {
              fontWeight: 'bold',
            },
          }}
        >
          <>
            <Stack.Screen 
              name="Login" 
              component={Login} 
            />
            <Stack.Screen
              name="Signup"
              component={Signup}
            />
            <Stack.Screen 
              name="ForgotPassword"
              component={forgotPassword}
            /> 
          </>
        </Stack.Navigator>
      </NavigationContainer>
    )
  }
    
  return (
    <NavigationContainer>  
      <Stack.Navigator
        screenOptions={{
          headerTitleAlign: 'center',
          headerStyle: {
            backgroundColor: '#3740FE',
          },
          headerTintColor: '#fff',
          headerTitleStyle: {
            fontWeight: 'bold',
          },
        }}
      >
        <>
          <Stack.Screen
            name="Dashboard"
            component={DashboardScreen}
            options={{
              headerLeft:  props => 
                <IconButton
                  {...props}
                  icon="menu"
                  color="white"
                  onPress={() => navigation.dispatch(DrawerActions.toggleDrawer())}
                />,
              headerRight: props => 
                <IconButton
                  {...props}
                  icon="magnify"
                  color="white"
                />
            }}
          />
        </>
      </Stack.Navigator>
    </NavigationContainer>
  )
}

仪表板:


import 'react-native-paper'
import React from 'react';
import { StyleSheet, View} from 'react-native';
import {Button} from 'react-native-paper'

import { createDrawerNavigator } from '@react-navigation/drawer'


function HomeScreen ({navigation}) {

    return (
  
      <View>
        <Button
          onPress={() => navigation.navigate('Settings')}
        />
      </View>
    );
  }
  
  function SettingsScreen ({navigation}) {
  
    return (
  
      <View> style={styles.container}
        <Text>
          TESTING
        </Text>
      </View>
    );
  }
  
  const Drawer = createDrawerNavigator();

  export default function DashboardScreen (){

    return (
        <Drawer.Navigator initialRouteName="Home">
          <Drawer.Screen name="Home" component={HomeScreen}/>
          <Drawer.Screen name="Settings" component={SettingsScreen}/>
        </Drawer.Navigator> 
      
    );        
  }

const styles = StyleSheet.create({
  container: {
    flex: 1,
    display: "flex",
    justifyContent: 'center',
    alignItems: 'center',
    padding: 35,
    backgroundColor: '#fff'
  },
  textStyle: {
    fontSize: 15,
    marginBottom: 20
  }
});

1个回答

你可以在编写optionsin 函数时得到它

<Stack.Screen
            name="Dashboard"
            component={DashboardScreen}
            options={({navigation})=>({
              headerLeft:  props => 
                <IconButton
                  {...props}
                  icon="menu"
                  color="white"
                  onPress={() => navigation.dispatch(DrawerActions.toggleDrawer())}
                />
            })}
          />