Sam*_*her 0 javascript reactjs react-native asyncstorage
与React-Native项目合作,我决定根据官方文档为 AsyncStorage 编写一个允许使用对象的小型服务
import {AsyncStorage} from "react-native-web";
export async function getUserFromStore() {
try {
const user = await AsyncStorage.getItem('userData');
return JSON.parse(user);
} catch (error) {
console.log('ERROR. Trying to get user data to store, got ', error)
}
}
export async function saveUserToStore(data) {
await AsyncStorage.setItem(
'userData',
JSON.stringify(data),
(error) => {
console.log('ERROR. Trying to set user data to store, got ', error)
}
);
}
Run Code Online (Sandbox Code Playgroud)
我在登录期间设置用户数据对象。我正在进入主要组件以决定要呈现的内容
const AppStackScreen = () => (
<AppStack.Navigator>
<AppStack.Screen name="Tabbed" component={TabsScreenNavigationScreen} />
</AppStack.Navigator>
);
export default () => {
const user = AsyncStoreService.getUserFromStore();
console.log('GOT USER', user)
return (
<NavigationContainer>
{user ?
<AppStackScreen/>
:
<AuthStackNavigationScreen/>
}
</NavigationContainer>
)
};
Run Code Online (Sandbox Code Playgroud)
所以我需要得到像这样的对象{name: 'John', mail: 'john@mail.loc},但我得到的不是这个,而是Promise{[[PromiseStatus: 'resolved']], [[PromiseValue: {name: 'John', mail: 'john@mail.loc}]]}
为什么会发生以及为什么我没有使用用户参数获取对象
| 归档时间: |
|
| 查看次数: |
87 次 |
| 最近记录: |