我们还是来看看官网文档,AsyncStorage提供的方法如下:
static getItem(key: string, callback?: ?(error: ?Error, result: ?string) => void)
读取key字段并将结果作为第二个参数传递给callback。如果有任何错误发生,则会传递一个Error对象作为第一个参数。返回一个Promise对象。
static setItem(key: string, value: string, callback?: ?(error: ?Error) => void)
将key字段的值设置成value,并在完成后调用callback函数。如果有任何错误发生,则会传递一个Error对象作为第一个参数。返回一个Promise对象。static removeItem(key: string, callback?: ?(error: ?Error) => void)
删除一个字段。返回一个Promise对象。static mergeItem(key: string, value: string, callback?: ?(error: ?Error) => void)
假设已有的值和新的值都是字符串化的JSON,则将两个值合并。返回一个Promise对象。还没有被所有原生实现都支持。static clear(callback?: ?(error: ?Error) => void)
删除全部的AsyncStorage数据,不论来自什么库或调用者。通常不应该调用这个函数——使用removeItem或者multiRemove来清除你自己的key。返回一个Promise对象。static getAllKeys(callback?: ?(error: ?Error, keys: ?Array<string>) => void)
获取所有本应用可以访问到的数据,不论来自什么库或调用者。返回一个Promise对象。static flushGetRequests()
清除所有进行中的查询操作。static multiGet(keys: Array<string>, callback?: ?(errors: ?Array<Error>, result: ?Array<Array<string>>) => void)
获取keys所包含的所有字段的值,调用callback回调函数时返回一个key-value数组形式的数组。返回一个Promise对象。multiGet(['k1', 'k2'], cb) -> cb([['k1', 'val1'], ['k2', 'val2']])
static multiSet(keyValuePairs: Array<Array<string>>, callback?: ?(errors: ?Array<Error>) => void)
multiSet和multiMerge都接受一个与multiGet输出值一致的key-value数组的数组。返回一个Promise对象。multiSet([['k1', 'val1'], ['k2', 'val2']], cb);
static multiRemove(keys: Array<string>, callback?: ?(errors: ?Array<Error>) => void)
删除所有键在keys数组中的数据。返回一个Promise对象。static multiMerge(keyValuePairs: Array<Array<string>>, callback?: ?(errors: ?Array<Error>) => void)
将多个输入的值和已有的值合并,要求都是字符串化的JSON。返回一个Promise对象。还没有被所有原生实现都支持。
我们还是来看看例子:
我们实现一个效果,给一个key设置一个值并在界面显示
删除这个key,如果存在值,那么删除它,如果不存在提示。
设置值:
setData(text){ AsyncStorage.setItem(AsyncStorageKey,text,()=>{ this.setState({ data:text, }); }); }注意可以设置一个回调,设置成功后,调用回调,修改状态机变量
删除值:
delData(){ // 读取key字段并将结果作为第二个参数传递给callback。 // 如果有任何错误发生,则会传递一个Error对象作为第一个参数。返回一个Promise对象。 AsyncStorage.getItem(AsyncStorageKey,(error,text)=>{ if(text=== null ){ alert(AsyncStorageKey +"没有对应的值"); }else{ //删除数据 AsyncStorage.removeItem(AsyncStorageKey,()=>{ this.setState({ data:"", },()=>{ alert('删除成功'); }); }); } }); }
我们发现在RN中很多地方都是通过回调来实现一些功能。
Demo实现的效果如下:
完整代码如下:
'use strict'; import React, { Component } from 'react'; import { StyleSheet, View, Text, TouchableHighlight, Dimensions, AsyncStorage } from 'react-native'; const {width, height} = Dimensions.get('window'); var data = ""; const AsyncStorageKey = "AS_"; export default class AsyncStorageExample extends Component { constructor(props) { super(props); this.state = { data:"" }; } setData(text){ AsyncStorage.setItem(AsyncStorageKey,text,()=>{ this.setState({ data:text, }); }); } delData(){ // 读取key字段并将结果作为第二个参数传递给callback。 // 如果有任何错误发生,则会传递一个Error对象作为第一个参数。返回一个Promise对象。 AsyncStorage.getItem(AsyncStorageKey,(error,text)=>{ if(text=== null ){ alert(AsyncStorageKey +"没有对应的值"); }else{ //删除数据 AsyncStorage.removeItem(AsyncStorageKey,()=>{ this.setState({ data:"", },()=>{ alert('删除成功'); }); }); } }); } render() { return ( <View style={styles.container}> <TouchableHighlight style={styles.itemView} underlayColor="red" onPress={this.setData.bind(this,"我是小刀")}> <Text style={styles.itemText}> 1、存储数据 </Text> </TouchableHighlight> <TouchableHighlight style={styles.itemView} underlayColor="red" onPress={this.delData.bind(this)}> <Text style={styles.itemText}> 2、删除数据 </Text> </TouchableHighlight> <Text style={{paddingTop:40}}> AsyncStorage存储的值是:{this.state.data} </Text> </View> ); } } const styles = StyleSheet.create({ container: { flex: 1, backgroundColor: '#f2f2f2', paddingTop:20, }, itemView:{ backgroundColor:'grey', height:44, width:width, justifyContent:'center', marginTop:10, }, itemText:{ fontSize:15, color:'#ffffff', textAlign:'left', marginLeft:20, }, });