警告:无法从其他组件的功能主体内部更新组件。 (反应本机)

时间:2020-10-23 18:05:15

标签: javascript reactjs react-native

我是React Native和javascript的新手。正在尝试在init页面上使用身份验证流,以查看用户isLoggedIn是否将其重定向到相应页面。该消息显示用户何时登录,并导航到另一页。

错误消息, screenshot

这是“验证”页面上使用的代码。

    import React from 'react';
import { View, Text, TouchableOpacity } from 'react-native';
import { FontAwesome5 } from '@expo/vector-icons';
import { useNavigation } from '@react-navigation/native';
import styles from './styles';

import { isSignedIn, getUserType } from '../../services/auth';

export default function(){

    const navigation = useNavigation()

    async function goToLoginOng(){
        navigation.navigate('Login', {
            userType: 'ong',
            route: 'sessions'
        })
    }
    async function goToLoginUser(){
        navigation.navigate('Login', {
            userType: 'user',
            route: 'userlogin'
        })
    }

    async function userisLogged() {
        if (isSignedIn){
            const userType = getUserType();
            if (userType === 'user'){
                navigation.navigate('Incidents')
            }
            else {
                navigation.navigate('Profile')
            }
        }
    }

    userisLogged();

    return(
        <View style={styles.container}>
            <Text style={styles.bigQuestion} >Quem é você?</Text>
            <TouchableOpacity style={styles.box} onPress={goToLoginUser}>
                <FontAwesome5 name='user' size={60} color='#FFF' style={styles.iconStyle} />
                <Text style={styles.title}>Pessoa</Text>
            </TouchableOpacity>
            <TouchableOpacity style={styles.box} onPress={goToLoginOng}>
                <FontAwesome5 name='users' size={60} color='#FFF' style={styles.iconStyle} />
                <Text style={styles.title}>ONG</Text>
            </TouchableOpacity>
        </View>
    )
}

这里是我使用的身份验证功能。

    import React from 'react';
import { AsyncStorage } from 'react-native';

export const isSignedIn = async() => {
    const response =  await AsyncStorage.getItem('userToken')
    if (response !== null){
        return true
    }
    else {
        return false
    }
}

export const getUserType = async () => {
    const response =  await AsyncStorage.getItem('userType')
    return response;
}

请对此表示感谢,如果您可以提出改进的建议,或者是另一种最好的解决方法,我将在此先感谢。

1 个答案:

答案 0 :(得分:0)

我认为问题在于userisLogged()是直接在功能组件内部触发的。

这意味着userisLogged()会在呈现此“身份验证”页面时触发。

因此,该功能在页面最初呈现时触发一次。

这可以通过使用useEffect挂钩来实现。

useEffect(() => {
   userisLogged()
}, [])

以上代码在类组件中等于componentDidMount()