我有一个带有按钮的登录屏幕,记住我,当我连接时,我想将此信息存储在这样的异步存储中:
if (this.isFormValid()) {
AccountService.login(login, password)
.promise.then(body => {
console.log('onLoginClick -> body', body)
Keyboard.dismiss()
AsyncStorage.setItem('login', login)
if (this.state.isRememberMeSelected) {
console.log("i'm in the storage !")
AsyncStorage.multiSet([['login', login], ['password',
password], ['isRememberMeSelected', '1']])
} else {
AsyncStorage.multiSet([['login', ''][('password', '')],
['isRememberMeSelected', '0']])
}
当我回到抽屉时,我尝试读取存储并获取值“ isRememberMeSelected”:
async componentDidMount() {
// await AsyncStorage.getItem('login').then(value => {
// console.log('DrawerLogin', value)
// //this.setState({login: value})
// })
// await AsyncStorage.getItem('password').then(value => {
// console.log('DrawerPassword', value)
// //this.setState({password: value})
// })
await AsyncStorage.getItem('isRememberMeSelected').then(value => {
console.log('DrawerIsRememberMeSelected', value)
this.setState({isRememberMeSelected: value})
})
// await AsyncStorage.getAllKeys((err, keys) => {
// console.log(' Allkeys', keys)
// })
}
在我的抽屉中,检查值“ isRememberMeSelected”以删除一些项目:
StorageMultiRemove = async () => {
try {
await AsyncStorage.multiRemove(['refreshToken',
'stripeCustomerId', 'token'], err => {
console.log(' Dans multiRemove Error', err)
})
} catch (error) {
// Error saving data
}
}
isRememberMeSelected === '1' ? this.StorageMultiRemove() :
AsyncStorage.clear()
当我回到抽屉中时,此值始终为null(除非我离开应用程序并重新启动...),否则一切设置都很好。...
我非常适合自己的状况(执行setItem之前的状况)...
我想将此数据记录在asynStorage中,返回到我的抽屉中并具有这些值
答案 0 :(得分:1)
您可以添加一个变量,该变量将在获取异步存储后发生变化
class Myform extends React.Component {
state = {
loading: true
}
然后组件中的组件确实安装了更新状态
componentDidMount() {
await AsyncStorage.getItem('isRememberMeSelected').then(value => {
console.log('DrawerIsRememberMeSelected', value)
this.setState({
isRememberMeSelected: value,
loading: false
})
})
}
和渲染
render() {
if(loading) return; // could return loading spinner or something
}