我是React Native和javascript的新手。正在尝试在init页面上使用身份验证流,以查看用户isLoggedIn是否将其重定向到相应页面。该消息显示用户何时登录,并导航到另一页。
错误消息,
这是“验证”页面上使用的代码。
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;
}
请对此表示感谢,如果您可以提出改进的建议,或者是另一种最好的解决方法,我将在此先感谢。
答案 0 :(得分:0)
我认为问题在于userisLogged()
是直接在功能组件内部触发的。
这意味着userisLogged()
会在呈现此“身份验证”页面时触发。
因此,该功能在页面最初呈现时触发一次。
这可以通过使用useEffect
挂钩来实现。
useEffect(() => {
userisLogged()
}, [])
以上代码在类组件中等于componentDidMount()
。