ReactNative学习实例(九)数据永久化存储AsyncStorage

官方的使用文档在这里http://reactnative.cn/docs/0.43/asyncstorage.html#content


AsyncStorage使用类似于安卓中sharedpreference的存储逻辑,从名字中就可以看出这是异步存储。调用的所有方法返回一个Promise对象,但是不需要对这个对象进行操作,因为方法接受回调方法等参数,在这些方法中对数据进行存取即可。


这里以最简单的存取一个键值对为例:

首先来看文档中的介绍:

staticgetItem(key: string, callback?: ?(error: ?Error, result: ?string) => void) 

读取key字段并将结果作为第二个参数传递给callback。如果有任何错误发生,则会传递一个Error对象作为第一个参数。返回一个Promise对象。

staticsetItem(key: string, value: string, callback?: ?(error: ?Error) => void) 

key字段的值设置成value,并在完成后调用callback函数。如果有任何错误发生,则会传递一个Error对象作为第一个参数。返回一个Promise对象。


首先是存方法:

AsyncStorage.setItem("key","我写入了",function (err){
            if(err){
                alert(err);
            }
        })
方法接收三个参数,前两个是键值,最后是完成后的回调方法,有一个error参数。可以对这个error参数进行if判断操作是否成功。


然后是取值(最好放在componentDidMount生命周期方法里):

componentDidMount() {
        let _that=this;
        AsyncStorage.getItem("key",function (err,result){
            if(err){
                alert(err)
            } else{

                _that.setState({text:result});
            }
        });
    }
取方法两个参数,第一个是键,第二个是回调方法,有error和结果两个参数。首先判断有无错误,然后取出结果。由于涉及this操作这里传入了this。



别忘了引入,AsyncStorage和AppRegisty,StyleSheet一样都是全局组件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值