因此,我现在使用react原生中的AsyncStorage来存储使用axios发出请求的api。当我调用AsyncStorage来获取一个item时,我得到的是Object对象而不是键。
我尝试了异步等待函数来解析promise以获得值,但我仍然得到promise而不是promise中的值。我还尝试用then返回值,然后返回值。
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'
}
});发布于 2019-07-15 05:37:42
AsyncStorage将数据保存为字符串。您是否尝试过在保存之前对键调用JSON.stringify,并在从存储中检索值之后调用JSON.parse?
https://stackoverflow.com/questions/57030954
复制相似问题