开发者问题收集

REACT NATIVE 问题 TypeError:未定义不是对象(评估“navigation.navigate”)......,

2022-10-02
165
App.js (Login)
    import * as React from 'react';
    import {useState} from 'react';
    import { Text, StyleSheet, 
    KeyboardAvoidingView, ScrollView, Image,
    TextInput, TouchableOpacity, View } from 'react-native';
    import { CheckBox } from 'react-native-elements';
    import {Ionicons} from '@expo/vector-icons'
    import {statusBar01} from './src/statusBar';
    
    
    
    
    const Login = ({navigation}) => {
    const [input, setInput] = useState('');
    const [hidePass, setHidePass] = useState(true);
    const [ischecked1, setIschecked1] = useState(true)
    //const navigation = useNavigation(); 
    
    
    return (
        
        <KeyboardAvoidingView
            style={styles.container}
        >
            <ScrollView>
                <Image
                    source={require('./assets/logo.png')}
                    style={styles.logo}
                />
                <Text style={styles.helloText}> 
                    Olá de novo !
                </Text>
                <Text style={styles.welcomeText}>
                    Bem-vindo(a) de volta,
                    sentimos sua falta! 
                </Text>
                
                <TextInput
                    style={styles.inputArea}
                    placeholder="Digite o e-mail"
                />
                <TextInput
                    style={styles.inputArea}
                    placeholder="Senha"
                    value={input}
                    onChangeText={ (texto) => setInput(texto)}
                    secureTextEntry={hidePass}
                />
                <TouchableOpacity style={styles.eye} onPress={ () => setHidePass(!hidePass) }>
                    <Ionicons name={hidePass ? 'eye' : 'eye-off'}
                        color="#A0D800" size={25}
                    />
                </TouchableOpacity>
                <View style={styles.checkBoxStyle}>
                    <CheckBox
                        left
                        size={18}
                        checkedColor='#A0D800'
                        value={ischecked1}
                        checked={ischecked1}
                        onPress={() => setIschecked1(!ischecked1)}
    
                        containerStyle={{ backgroundColor: "transparent",
                        borderColor: "transparent", marginRight: 0}}
                    />
                    <TouchableOpacity>
                    <Text style={styles.Connected}> 
                        Manter-se conectado
                    </Text>
                    </TouchableOpacity>
    
                    <TouchableOpacity>
                    <Text style={styles.forgotPassword}> 
                        Esqueci minha senha
                    </Text>
                    </TouchableOpacity>
                </View>
                
    
                <TouchableOpacity 
                    style={styles.botao}
                    
                    onPress={() => navigation.navigate('HomeScreen')}
                >
                    <Text style={styles.botaoText}>Entrar</Text>
                </TouchableOpacity>
            </ScrollView>
        </KeyboardAvoidingView>
    );
    
    }
    const styles = StyleSheet.create({
    container: {
        flex: 2,
        justifyContent: 'center',
        alignItems: 'center',
        backgroundColor: '#fff'
    },
    logo: {      
        marginTop:50,
        marginBottom: 80,
        width: 150,
        height: 40,
        
    },
    inputArea:{
       marginTop: 30,
       padding: 15,
       height: 60,
       width: 370,
       borderColor: '#808080',
       borderWidth: 1,
       backgroundColor: '#fff',
       fontSize: 16,
       fontWeight: 'bold',
       borderRadius: 15
    },
    botao: {
        width: 350,
        height: 60,
        backgroundColor: '#000000',
        marginTop: 35,
        marginLeft: 8,
        borderRadius: 15,
        alignItems: 'center',
        justifyContent: 'center',
        
    },
    botaoText: {
      fontSize: 15,
      fontWeight: 'bold',
      color: '#fff'
    },
    helloText: {
      fontSize: 40,
      fontWeight: 'bold',
      marginTop: 15,
      color: '#000000',
      marginEnd: 120,
      marginTop: 8
    },
    welcomeText: {
      fontSize: 16,
      marginTop: 10,
      marginEnd: 35,
      marginVertical: 10,
      color: '#808080',
    },
    forgotPassword: {
      textDecorationLine: 'underline',
      fontWeight: 'bold',
      marginTop: 15,
      marginBottom: 15,
      marginLeft: 30,
      fontSize: 12
    },
    Connected:{
      textDecorationLine: 'underline',
      fontWeight: 'bold',
      marginTop: 15,
      fontSize: 12,
      marginRight: 55,
      marginLeft: -5
    },
    checkBoxStyle:{
      marginTop: 15,
      flexDirection: 'row',
      marginStart: -10
    },
    eye:{
    alignSelf: 'flex-end',
    bottom: 42,
    right: 40
    }
    })
    
    export default Login;
    
    HomeScreen.js
    
    
    import * as React from 'react';
    import { useState } from 'react';
    import { Text, View, ScrollView, KeyboardAvoidingView, Image, TouchableOpacity} from 'react-native';
    import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
    import { Entypo, Feather } from 'react-native-vector-icons';
    import SwitchSelector from "react-native-switch-selector";
    import {Card} from 'react-native-shadow-cards';
    import * as Progress from 'react-native-progress';
    import { NavigationContainer } from '@react-navigation/native';
    import statusBar01 from './src/statusBar';
    import 'react-native-gesture-handler';
    import {createStackNavigator} from 'react-navigation/stack'
    
    import Login from '../../App';
    //import { HomeScreen } from './src/screens/HomeScreen';
    //import { TasksScreen } from './src/screens/TasksScreen';
    //import { SettingsScreen } from './src/screens/SettingsScreen';
    
    
    
    function TasksScreen() {
    
      return (
        <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
          <Text>Tasks!</Text>
        </View>
      );
    }
    
    function HomeScreen() {
        const options = [
          { label: "Active", value: "a" },
          { label: "New", value: "n" },
        ];
        const [showHide, setShowHide] = useState(false);
        
    
      return (
        <KeyboardAvoidingView style={{
          flex: 2,
          justifyContent: 'center',
          alignItems: 'center',
          backgroundColor: '#fff'
        }}>
          <ScrollView >
        
          <Text style={{textAlign:'left', fontSize: 33,
           fontWeight:'bold', paddingTop: 100,
           paddingLeft: 20, bottom: 55}}>
           {'Olá, \nUsuário!'}
          </Text>
    
          <Text style={{paddingLeft: 20,
               color: '#808080', bottom: 80,
               fontSize: 20 , paddingTop: 50}}>
              Minhas tasks</Text>
    
          <Image
          source={require('./assets/images/user.jpeg')}
          style={{marginTop:50,
            width: 55,
            height: 55,
            borderRadius: 10,
            top: -250,
            left: 300,
            borderColor: '#ECECEC',
            borderWidth: 1
           }    
          }
            />
    
            <SwitchSelector 
            style={{width:390,paddingLeft: 15, bottom: 160}}
            textColor={'#FFFFFF'}
            selectedColor={'#000000'}
            fontSize={15}
            height={60}
            bold
            backgroundColor={'#000000'}
            valuePadding={-1}
            hasPadding
            borderRadius={15}
            options={options}
            initial={0}
            //onPress={value => console.log(`Call onPress with value: ${value}`)}
             />
    
          <Card style={{ margin: 19, height: 170,
             marginTop: -125}}>
           <Feather name={'file-text'}
           color={'#F2CB1D'} 
           size={20}
           style={{paddingLeft: 20, 
           top: 20,}}/>
            <Text
            style={{paddingLeft: 50}}>Task 59788</Text>
            <Entypo name={'controller-record'}
            style={{paddingLeft: 270, bottom: 14
           }}
            color={'#007ACC'}
            size={10}
            />
            <Text
            style={{paddingLeft: 290, bottom: 30}}
            >Active</Text>
            <Text style={{fontSize: 12,
            paddingLeft: 20, bottom: 15
            }}>App corporativo OnlineTeam</Text>
            <Text style={{paddingLeft: 20,
            fontSize: 20, bottom: 10}}>Criar telas no Figma</Text>
            <Text style={{paddingLeft: 20, 
            fontSize: 12}}>Original Estimate: 4h</Text>
            <Text style={{paddingLeft: 250,
            bottom: 17, fontSize: 12}}>Completed: 2h</Text>
    
            <Text style={{textAlign: 'left',
            bottom: 10, fontSize: 10,
             paddingLeft: 55}}>
            0%</Text> 
            <Progress.Bar progress={0.1} 
            width={200}
            color={'#A0D800'}
            backgroundColor={'#ECECEC'}
            borderColor={'transparent'}
            height={10}
            borderRadius={10}
            style={{alignSelf: 'center'}}
            bottom={20}
            
             />
             <Text style={{textAlign: 'right',
              fontSize: 10,bottom: 35, 
              paddingRight: 40}}>
              100%</Text>
    
    
    
          </Card>
    
          <Card style={{ margin: 19, height: 170,
             marginTop: -125, marginTop: 5}}>
           <Entypo name={'bug'}
           color={'#FF0000'} 
           size={20}
           style={{paddingLeft: 20, 
           top: 20,}}/>
            <Text
            style={{paddingLeft: 50}}>Bug 59352</Text>
            <Entypo name={'controller-record'}
            style={{paddingLeft: 270, bottom: 14
          }}
            color={'#FF0000'}
            size={10}
            />
    
            <Text
            style={{paddingLeft: 290, bottom: 30}}
            >Issue</Text>
            <Text style={{fontSize: 12,
            paddingLeft: 20, bottom: 15
            }}>Cargo Online Team</Text>
            <Text style={{paddingLeft: 20,
            fontSize: 20, bottom: 10}}>
            Acusando duplicidade de contrato...</Text>
            <Text style={{paddingLeft: 20, 
            fontSize: 12}}>Original Estimate: 4h</Text>
            <Text style={{paddingLeft: 250,
            bottom: 17, fontSize: 12}}>Completed: 2h</Text>
            <Text style={{textAlign: 'left',
            bottom: 10, fontSize: 10,
             paddingLeft: 55}}>
            0%</Text> 
            <Progress.Bar progress={0.1} 
            width={200}
            color={'#A0D800'}
            backgroundColor={'#ECECEC'}
            borderColor={'transparent'}
            height={10}
            borderRadius={10}
            style={{alignSelf: 'center'}}
            bottom={20}
            
             />
             <Text style={{textAlign: 'right',
              fontSize: 10,bottom: 35, 
              paddingRight: 40}}>
              100%</Text>
    
          </Card>
    
          </ScrollView>
        </KeyboardAvoidingView>
          
    
      );
    }
    
      function SettingsScreen() {
        return (
          <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center'  }}>
            <Text>Settings!</Text>
          </View>
        );
      }
    
    
    
    
    
    
    export default function App() {
      const Tab = createBottomTabNavigator();
      return (
        <NavigationContainer>
          <Tab.Navigator 
    
          screenOptions={{
            tabBarActiveTintColor: "#A0D800",
            tabBarInactiveTintColor: "#FFFFFF",
            //tabBarActiveBackgroundColor: "#FFFFFF",
            //tabBarInactiveBackgroundColor: "#000000",
            backgroundColor: "#FFFFFF",
            
            headerShown: false,
            
    
            tabBarSelectedItemStyle: {
              borderBottomWidth: 2,
              borderBottomColor: 'red',
            },
            
            tabBarStyle: [
              {
                display: "flex",
                backgroundColor: "#000000",
                borderTopLeftRadius: 20,
                borderTopRightRadius: 20,
                height: 70,
                overflow: 'hidden',
                alignItems: 'center',
                justifyContent: 'center', 
                
                
              },
              
              null,
            ], 
            tabBarHideOnKeyboard: true,
    
    
            tabBarLabelStyle:{
    
              //fontSize: 20,
              //fontWeight: 'bold',
              
              backgroundColor: "#000000",
              width: 60,
              flex: 0.000004,   
    
            },
    
            
          }}
          >
              
            <Tab.Screen name="  " 
            component={TasksScreen}
            options={{
              tabBarIcon: ({ color}) => (
                <Entypo name="add-to-list" 
                size={30}
                color={color}
                
                 />
                )
            }}
             />
    
            <Tab.Screen name=" " 
            component={HomeScreen}
            options={{
              tabBarIcon: ({ color}) => (
                <Feather name="home" 
                size={30}
                color={color}
                 />
                )
            }} />
            
            
            <Tab.Screen name="   " 
            component={SettingsScreen}
            options={{
              tabBarIcon: ({ color}) => (
                <Feather name="settings" 
                size={30}
                color={color}
            
             />
            )
        }}
         />
      </Tab.Navigator>
    </NavigationContainer>
    );
  }

我无法组织代码或在主屏幕的登录按钮上实现导航,有人能帮帮我吗??? 我尝试创建一个 Login.js 并将其和 HomeScreen 导出到 App.js,但也失败了。 有人能帮我解决这个问题,让我可以继续编写代码吗? 我需要这方面的帮助 我是初级开发人员 请 :( :( :(

3个回答

不要依赖于获取导航对象作为 prop,而是从 react-navigation/core 导入 useNavigation

import { useNavigation } from '@react-navigation/core';

export default function App(){
   const navigation = useNavigation()


   return(
   <View>
     <Button onPress={()=> navigation.navigate("homescreen")}/>
   </View>
   
   )
 }
eeshankeni
2022-10-02

看来您没有导入 useNavigation。将其添加到您的代码中:

import { useNavigation } from '@react-navigation/native';

然后在您的登录函数中声明一个 const:

const navigation = useNavigation();

然后重试。同时确保您在 navigation.navigate('') 中调用了正确的组件名称

Loju
2022-10-02

您应该为屏幕定义名称。

例如:

<Tab.Screen name="TasksScreen" 
        component={TasksScreen}
        options={{
          tabBarIcon: ({ color}) => (
            <Entypo name="add-to-list" 
            size={30}
            color={color}
            
             />
            )
        }}
         />

        <Tab.Screen name="HomeScreen" 
        component={HomeScreen}
        options={{
          tabBarIcon: ({ color}) => (
            <Feather name="home" 
            size={30}
            color={color}
             />
            )
        }} />
        
        
        <Tab.Screen name="SettingsScreen" 
        component={SettingsScreen}
        options={{
          tabBarIcon: ({ color}) => (
            <Feather name="settings" 
            size={30}
            color={color}
        
         />

然后您可以使用它们的名称进行导航,例如 navigation.navigate("HomeScreen")

您应该仔细命名它们。

有关详细信息和示例,您可以查看: https://reactnative.dev/docs/navigation

祝您有美好的一天!

kantarovski
2022-10-02