使用React Native保存状态的AsyncStorage

时间:2017-07-20 13:05:55

标签: firebase react-native firebase-realtime-database state asyncstorage

我想保存切换按钮状态,以便用户不能投票两次。 我有一条消息错误:异常' - [NSDictionaryM长度...在目标AsyncLocalStorage上调用multiSet时抛出任何想法?

this.state= {
trueSwitchIsOn: false,
}; 

 onSwitchChange(_key){
 const{trueSwitchIsOn}=this.state;

          switch (this.state.trueSwitchIsOn){
            case false:
              return(
                <TouchableHighlight onClick={this.onPressIcon(_key)}>
                {this.setState({trueSwitchIsOn: true})}
                </TouchableHighlight>
                );
            case true:
              return(
              <TouchableHighlight onClick={this.onUnPressIcon(_key)}>
                {this.setState({trueSwitchIsOn: false})}
                </TouchableHighlight>
                );
              }
          }

onPressIcon(word){
          AsyncStorage.setItem('AlreadyLiked', {trueSwitchIsOn});
          const{trueSwitchIsOn}=this.state;
          this.setState({trueSwitchIsOn : true});
}
onUnPressIcon(word){ 
          AsyncStorage.setItem('NotAlreadyLiked', {trueSwitchIsOn: false});
          const{trueSwitchIsOn}=this.state;
          this.setState({trueSwitchIsOn : false});
<Switch>
         onValueChange={(value)=>this.onSwitchChange(_key)}
</Switch>

1 个答案:

答案 0 :(得分:3)

传递给AsyncStorage.setItem()的值必须是字符串。您需要将对象传递给JSON.stringify()或者只使用纯字符串值而不是带有&#34; trueSwitchIsOn&#34;的对象。布尔属性。