无法使用React Native Async Storage进行工作

11

我在使用React Native异步存储时遇到了困难。大部分时间,我的代码跳过了当前的执行步骤,并转到下一行,而没有从当前行获取结果。我大部分时间都会遇到错误。

我尝试了这个例子-

'use strict';

var React = require('react-native');
var {
  AsyncStorage,
  PickerIOS,
  Text,
  View
} = React;
var PickerItemIOS = PickerIOS.Item;

var STORAGE_KEY = '@AsyncStorageExample:key';
var COLORS = ['red', 'orange', 'yellow', 'green', 'blue'];

var BasicStorageExample = React.createClass({
  componentDidMount() {
    this._loadInitialState().done();
  },

  async _loadInitialState() {
    try {
      var value = await AsyncStorage.getItem(STORAGE_KEY);
      if (value !== null){
        this.setState({selectedValue: value});
        this._appendMessage('Recovered selection from disk: ' + value);
      } else {
        this._appendMessage('Initialized with no selection on disk.');
      }
    } catch (error) {
      this._appendMessage('AsyncStorage error: ' + error.message);
    }
  },

  getInitialState() {
    return {
      selectedValue: COLORS[0],
      messages: [],
    };
  },

  render() {
    var color = this.state.selectedValue;
    return (
      <View>
        <PickerIOS
          selectedValue={color}
          onValueChange={this._onValueChange}>
          {COLORS.map((value) => (
            <PickerItemIOS
              key={value}
              value={value}
              label={value}
            />
          ))}
        </PickerIOS>
        <Text>
          {'Selected: '}
          <Text style={{color}}>
            {this.state.selectedValue}
          </Text>
        </Text>
        <Text>{' '}</Text>
        <Text onPress={this._removeStorage}>
          Press here to remove from storage.
        </Text>
        <Text>{' '}</Text>
        <Text>Messages:</Text>
        {this.state.messages.map((m) => <Text key={m}>{m}</Text>)}
      </View>
    );
  },

  async _onValueChange(selectedValue) {
    this.setState({selectedValue});
    try {
      await AsyncStorage.setItem(STORAGE_KEY, selectedValue);
      this._appendMessage('Saved selection to disk: ' + selectedValue);
    } catch (error) {
      this._appendMessage('AsyncStorage error: ' + error.message);
    }
  },

  async _removeStorage() {
    try {
      await AsyncStorage.removeItem(STORAGE_KEY);
      this._appendMessage('Selection removed from disk.');
    } catch (error) {
      this._appendMessage('AsyncStorage error: ' + error.message);
    }
  },

  _appendMessage(message) {
    this.setState({messages: this.state.messages.concat(message)});
  },
});

exports.title = 'AsyncStorage';
exports.description = 'Asynchronous local disk storage.';
exports.examples = [
  {
    title: 'Basics - getItem, setItem, removeItem',
    render(): ReactElement { return <BasicStorageExample />; }
  },
];

这个可以正常运行。但是,我的函数没有按照预期工作,我得到了undefined


你能更具体地说明你遇到了哪些错误吗?此外,你在代码的哪个阶段遇到了这些错误? - Nader Dabit
我没有收到任何错误提示。功能的顺序不像我想要的那样执行。Lokesh的答案似乎是我的解决方案。那个Git仓库看起来非常容易实现。 - Manoj Kumar
3个回答

21

对于其他仍无法解决此问题的人:请使用react-native中的AsyncStorage,而不是React。

import { AsyncStorage } from 'react-native';

1
这应该放在顶部。它不在文档中,而且你得到的错误信息是没有描述性的。 - Gilbert Nwaiwu

8
阅读您的问题后,我首先感觉到的是“可能”您对ES7不熟悉,特别是async-await。请阅读有关ES7中即将在今年(2016年)发布的async-await函数的信息。
您的函数必须具有异步性质。在函数之前放置关键字async。在调用函数时必须使用await
具体而言,我建议您在开发中使用react-native-store存储库。React Native的开发人员已经明确表示要使用这个和其他实现,因为他们认为AsyncStorage有点复杂。

哇!这看起来像是一个很棒的React Native Store实现。例子非常简单,我会试一下。谢谢你告诉我关于async await的事情。 - Manoj Kumar

2

如果有人正在使用 AsyncStorage.multiSet([]),请确保您的值没有nullundefined。否则,它将不起作用,并且不会将值设置为有效的键值对。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接