【发布时间】:2019-12-07 21:32:16
【问题描述】:
版本:
@react-native-community/async-storage = ^1.6.1
问题:
- 像这样导入 AsyncStorage:
import { AsyncStorage } from '@react-native-community/async-storage'
- 在我的代码中这样使用:
AsyncStorage.setItem('locale', locale)
AsyncStorage.getItem('user').then((value) =>
{
...
}
错误:
- TypeError:未定义不是对象(评估 '_asyncStorage.AsyncStorage.setItem')
- TypeError: undefined is not an object(评估 '_asyncStorage.AsyncStorage.getItem')
我尝试过的
- 从 'react-native' 导入
AsyncStorage没有问题,只是警告应该从 '@react-native-community' 导入AsyncStorage,因为不推荐使用来自 'react-native' 的AsyncStorage。 - 尝试卸载并重新安装“@react-native-community/async-storage”-dependency,但没有成功。
- 谷歌搜索
完整代码:
import React from 'react';
import { View, Image, NativeModules } from 'react-native';
import { AsyncStorage } from '@react-native-community/async-storage'
import { styles } from '../../components/Styles.js';
import { GEOLocation } from '../../scripts/GEOLocation';
import Moment from 'moment/min/moment-with-locales';
export default class SplashScreen extends React.Component {
constructor(props) {
super(props);
this.geo = new GEOLocation();
this.setLocale();
this.bootstrapAsync();
}
bootstrapAsync = async () => {
this.geo.grantAccess()
AsyncStorage.getItem('user').then((value) => {
const user = JSON.parse(value);
this.props.navigation.navigate(user ? 'App' : 'Auth');
})
};
setLocale = () => {
const deviceLocale = NativeModules.I18nManager.localeIdentifier
var locale;
if (deviceLocale.includes('_')) {
var language = deviceLocale.split('_')[0]
var country = deviceLocale.split('_')[1].toLowerCase()
locale = language + '-' + country
} else {
locale = deviceLocale
}
if(Moment.locales().indexOf(locale) > -1 ) {
console.log('device locale')
AsyncStorage.setItem('locale', locale)
} else {
console.log('default locale')
AsyncStorage.setItem('locale', 'en')
}
}
render() {
return (
<View style={styles.container}>
<Image style={styles.leImage} source={require('../../../assets/logo_icon.png')} />
</View>
)
}
}
【问题讨论】: