1
 export default class Signin extends Component {

     state ={
         errorMessage: null
     }

这里我使用apisauce和credentials来测试连接

   signin = async() => {
       try{
         const response = await api.post('/auth/authenticate')({
             email:'teste93@teste.com',
             password:'123'
         })
    

         const {user, token} = response.data
         await AsyncStorage.multiSet([
             ['@backend : token', token]
             ['@backend : user',JSON.stringify(user) ]
         ])

博览会说错误就在这里

       }catch(response){
         this.setState({errorMessage: response.data.error})
       }
    
   }

   render() {
      return (
       <View style={styles.Container}>
            { this.state.errorMessage && <Text>{ this.state.errorMessage }</Text> }
         <Button onPress={this.signin} title="Entrar"/>
       </View>
     );
   }
 }

这里是我的服务/api

 import { create } from 'apisauce'


 const api = create({
     baseURL: 'http://locahost:300'
 })

 api.addResponseTransform(response => {
     if (!response.ok) throw response;
     console.log(response)
 })

 export default api;
4

1 回答 1

1

类型错误:未定义不是对象

此错误通常表明您正在尝试访问非对象类型的属性。块中暴露的值catch将是一个Error没有data属性的对象。

将您的catch块更改为以下内容。

} catch (error) {
  this.setState({errorMessage: error.message})
}
于 2021-01-08T23:13:17.413 回答