Javascript 响应本机异步存储承诺
因此,我现在正在使用react native中的AsyncStorage来存储api密钥,以便使用axios发出请求。当我调用AsyncStorage来获取项目时,我得到的是[Object Object],而不是键 我尝试了async Wait函数来解析承诺以获得值,但我仍然获得了承诺,而不是承诺中的值。我还尝试返回一个值,然后返回该值Javascript 响应本机异步存储承诺,javascript,react-native,axios,Javascript,React Native,Axios,因此,我现在正在使用react native中的AsyncStorage来存储api密钥,以便使用axios发出请求。当我调用AsyncStorage来获取项目时,我得到的是[Object Object],而不是键 我尝试了async Wait函数来解析承诺以获得值,但我仍然获得了承诺,而不是承诺中的值。我还尝试返回一个值,然后返回该值 import {AsyncStorage} from 'react-native'; class APIToken { constructor(){}
import {AsyncStorage} from 'react-native';
class APIToken {
constructor(){}
async get(){
try {
const token = await AsyncStorage.getItem('api_token');
if (token !== null) {
// We have data!!
console.log(token);
return token
}
} catch (error) {
// Error retrieving data
}
//return null
}
async set(token){
try {
await AsyncStorage.setItem('api_token', token);
return token
} catch (error) {
// Error saving data
}
//return null
}
}
export default APIToken
const key = async function() {
const k = await (new APIToken()).get()
return k
}
const api = axios.create({
baseURL: Config.API_URL_V1,
headers: {
'Content-Type': 'application/json',
'Authorization': 'Bearer ' + key(),
'Cache-Control': 'no-cache'
}
});
异步存储将数据保存为字符串。
您是否在保存前尝试调用键上的JSON.stringify,在从存储中检索值后尝试调用JSON.parse?我将该值存储为一个字符串