Javascript 反应本机:可能未处理的承诺拒绝(id:0)类型错误:网络请求失败
我收到以下错误:可能未处理的承诺拒绝(id:0):网络请求失败。 我试图用firebase中的文字和图片传达评论。在ReviewsScreen.js中实现数据的显示和接受,在Fire.js中实现数据的处理和发送。我认为Fire.js中的某个地方存在错误,但我不知道问题出在哪里 ReviewScreen.jsJavascript 反应本机:可能未处理的承诺拒绝(id:0)类型错误:网络请求失败,javascript,reactjs,firebase,react-native,firebase-realtime-database,Javascript,Reactjs,Firebase,React Native,Firebase Realtime Database,我收到以下错误:可能未处理的承诺拒绝(id:0):网络请求失败。 我试图用firebase中的文字和图片传达评论。在ReviewsScreen.js中实现数据的显示和接受,在Fire.js中实现数据的处理和发送。我认为Fire.js中的某个地方存在错误,但我不知道问题出在哪里 ReviewScreen.js import React, { Component } from 'react'; import { StyleSheet, View, TouchableOpacity,
import React, { Component } from 'react';
import {
StyleSheet,
View,
TouchableOpacity,
Text,
SafeAreaView,
Image,
TextInput,
SafeAreaViewBase
} from 'react-native';
import Icon from 'react-native-vector-icons/Ionicons'
import {h, w} from '../../constants'
import Fire from '../../Fire'
import ImagePicker from 'react-native-image-picker';
const options = {
title: 'Select photo',
};
export default class ReviewsScreen extends Component {
state = {
text: '',
image: null
}
pickImage = () => ImagePicker.showImagePicker(options, (response) => {
console.log('Response = ', response);
if (response.didCancel) {
console.log('User cancelled image picker');
} else if (response.error) {
console.log('ImagePicker Error: ', response.error);
} else {
// You can also display the image using data:
// const source = { uri: 'data:image/jpeg;base64,' + response.data };
this.setState({
image: response.uri
});
}
});
handleReview = () => {
Fire.shared.addReview({text: this.state.text.trim(), localUrl: this.state.image}).then(ref => {
this.setState({text: '', image: null})
this.props.navigation.goBack()
}).catch(error => {
alert(error)
})
}
render() {
return (
<SafeAreaView style={styles.container}>
<View style={styles.header}>
<TouchableOpacity onPress={() => this.props.navigation.goBack()}>
<Icon name='md-arrow-back' size={24} color='blue'/>
</TouchableOpacity>
<TouchableOpacity onPress={this.handleReview}>
<Text style={{fontWeight: '500'}}>Добавить</Text>
</TouchableOpacity>
</View>
<View style={styles.inputContainer}>
<Image source={require('./img/avatar.jpg')} style={styles.avatar}/>
<TextInput
autoFocus={true}
multiline={true}
numberOfLines={1}
style={{flex: 1}}
placeholder='Нам важно ваше мнение!'
onChangeText={text => this.setState({ text })}
value={this.state.text}
>
</TextInput>
</View>
<TouchableOpacity style={styles.photo}
onPress={this.pickImage}>
<Icon name='md-camera' size={32} color="#D8D9D8"></Icon>
</TouchableOpacity>
<View syle={{marginHorizontal: 32, marginTop: 32, height: 150}}>
<Image source={{uri: this.state.image}} style={{ marginTop: 32, alignSelf: 'center', width: '50%', height: '50%'}} />
</View>
</SafeAreaView>
)
}
}
您编写了“localUrl”而不是“localUri”:
Fire.shared.addReview({text:this.state.text.trim(),localUrl:this.state.image})。然后(ref=>{
您编写了“localUrl”而不是“localUri”:
Fire.shared.addReview({text:this.state.text.trim(),localUrl:this.state.image})。然后(ref=>{
任何时候,当您遇到未处理的承诺拒绝错误时,这意味着您在代码中的某个地方遇到了处理错误的问题。请尝试将您的函数包装在异步等待块中的Try-catch块中。@Uladzislau Rusy,您发现问题了吗?仍然有任何答案吗?保持不变。@Uladzislau每当您遇到未处理的承诺拒绝错误时,这意味着您在处理代码中的某个错误时遇到问题。请尝试将函数包装在异步等待块中的Try-catch块中。@Uladzislau-Rusy,您发现问题了吗?还有答案吗?仍然停留在同一个位置。@ula
import firebaseConfig from './config'
import firebase from 'firebase'
class Fire {
constructor() {
firebase.initializeApp(firebaseConfig);
}
addReview = async ({ text, localUri }) => {
const remoteUri = await this.uploadPhotoAsync(localUri);
return new Promise((res, rej) => {
this.firestore
.collection("reviews")
.add({
text,
uid: this.uid,
timestamp: this.timestamp,
image: remoteUri
})
.then(ref => {
res(ref);
})
.catch(error => {
rej(error)
});
});
};
uploadPhotoAsync = async uri => {
const path = `photos/${this.uid}/${Date.now()}.jpg`;
return new Promise(async (res, rej) => {
const response = await fetch(uri);
const file = await response.blob();
let upload = firebase
.storage()
.ref(path)
.put(file);
upload.on(
"state_changed",
snapshot => {},
err => {
rej(err);
},
async () => {
const url = await upload.snapshot.ref.getDownloadURL();
res(url);
}
);
});
};
get firestore() {
return firebase.firestore();
}
get uid() {
return (firebase.auth().currentUser || {}).uid;
}
get timestamp() {
return Date.now();
}
}
Fire.shared = new Fire();
export default Fire;