数据持久化就是指应用程序将某些数据存储在手机存储空间中。

借助native存储

这种方式不言而喻,就是把内容传递给native层,通过原生API存储,详见从零学React Native之05混合开发

AsyncStorage API

RN框架为开发者提供了 AsyncStorage API,开发者可以利用它将任意“字符串键值对”保存到存储空间中。

它是简单的,异步的。用它可以取代Android的sharedperference和ios的NSUserDefault。

AsyncStorage存储的数据对该RN应用全局都是可以访问的,只需要知道通过它增删改查数据就可以了。

写入数据

开发者可以通过静态函数setItem来存储数据。setItem的JavaScript原型是:

static object setItem(key, value,aCallBack)

写入数据有好几种方式,直接看代码:

    // 构造
constructor(props) {
super(props);
this.doSomething=this.doSomething.bind(this);
} doSomething(error){
if(error!=null){ //如发生错误 处理
console.log('error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log("name保存成功!");
}
//下面4种写法, 推荐第三种和第四种
componentWillMount() {
//最简单的写法 , 无法检测保存何时结束,是否成功
AsyncStorage.setItem('NO','01');
console.log("NO保存成功"); // 通过自带的回调方法,一旦发生出错就可以监控到
AsyncStorage.setItem('name','张三',this.doSomething); //Promise操作 ES2015推荐的写法
AsyncStorage.setItem('age',"18").then(
()=>{ //成功的操作
console.log("age保存成功!");
},
);
// 使用ES2017推荐的异步的写法
this.saveSex(); }
// 箭头函数不需要在构造函数中bind(this)了
saveSex = async ()=> {
try {
await AsyncStorage.setItem('sex','female');
console.log("sex保存成功!");
} catch(error) {
console.error(error);
}
};

输出结果:



当然, 还可以通过AsyncStorage的静态函数multiSet一次存储多个数据。

static object multiSet(aArray, aCallback)

//参数类型
multiSet([['k1', 'val1'], ['k2', 'val2']], cb);

Promise机制还可以通过下面的方式捕获异常,如果不了解Promise可以参考[React Native]Promise机制

        AsyncStorage.multiSet([['name','李四'],["sex","male"]])
.then(
()=>{
console.log("name,sex保存成功");
}
).catch((errors)=>{
console.log('error,length:'+errors.length);
if(errors.length>0){ //保存操作有异常
console.log(errors[0].message);
//...
}else{
//异常不是数组,有可能是成功操作的处理函数抛出的异常
//...
}
});

获取数据

可以通过AsyncStorage类的静态函数getItem获取数据,JS原型是:

static object getItem(aKey,aCallback)

直接看代码:

    componentWillMount() {

        //...

        //方式一 读取数据
AsyncStorage.getItem("name", this.handleResult); //方式二
AsyncStorage.getItem('sex')
.then( //使用Promise机制的方法
(result)=> { //使用Promise机制,如果操作成功不会有error参数
if (result == null) {
//没有指定的key
return;
}
console.log("sex:" + result);
}
).catch((error)=> { //读取操作失败
console.log('error:' + error.message);
});
} handleResult(error, result) {
if (error != null) {
console.log('error message:' + error.message);
return;
}
if (result == null) {
//没有指定的key
return;
}
console.log("name:" + result); }

当然也可以通过getAllKeys函数获取当前存储的所有键,再通过multiGet获取所有值。两个函数的原型分别是:

static object getAllkeys([aCallback])
static object multiGet(aArrays,aCallBack)

官方示例代码:

AsyncStorage.getAllKeys((err, keys) => {
AsyncStorage.multiGet(keys, (err, stores) => {
stores.map((result, i, store) => {
// get at each store's key/value so you can work with it
let key = store[i][0];
let value = store[i][1];
});
});
});

注意的是,AsyncStorage API存储数据是无序的。

开发者还可以通过AsyncStorage的静态函数flushGetRequests取消前面的所有未执行的完成的multiGet操作。

static object flushGetRequests()  

最好也借助Promise机制。

删除数据

删除数据通过 removeItem或者multiRemove 删除。 当然还可以通过clear函数全部清空。

函数原型:

static removeItem(key, callback?) 

static multiRemove(keys, callback?) 

static clear(callback?)

写法和上面差不多, 就不列举示例代码了。

JSON对象存储

使用AsyncStorage类保存数据,只能通过key-value形式保存一个字符串类型的数据。很难满足开发者的需求。

但是配合JSON类,把JSON格式的对象转换为一个字符串。然后通过AsyncStorage类的key-value形式进行保存,就可以满足绝大多数需求了。

我们借助下上篇文章中[React Native] 解析JSON文件 中的json文件,通过JSON类就可以转化为字符串了

let studentData = require('./data/student.json');
let newJSONString=JSON.stringify(studentData);

读取出来的字符串也可以转换回JSON对象。

let jsonObject=JSON.parse(newJSONString)

需要注意的是 JSONparse函数要求严格,不允许有尾逗号,如果有机会抛出异常,如下:

JSON.parse('{"name":"张三" ,}');

数据库

如果你想存放数据结构复杂的数据的时候,就需要用到数据库,比如sqlite这种跨平台的数据存储方式在ReactNative里也有对应的方式,那就是react-native-sqlite。点这里可以进行下载集成到应用程序中。

处理sqlite还有比较牛的就是realm,realm也支持react native了。大家可以按照官方文档去配置。

https://realm.io/docs/react-native/latest/

调用数据库相对复杂了,我们后面再详细介绍。

更多精彩请关注微信公众账号likeDev

从零学React Native之13 持久化存储的更多相关文章

  1. 从零学React Native之11 TextInput

    TextInput 组件是用来通过键盘输入文字,可以使用View组件和Text组件样式,没有自己特定的样式. 与Text组件类似,TextInput组件内部的元素不再使用FlexBox布局,而采用文本 ...

  2. 从零学React Native之03页面导航

    之前我们介绍了RN相关的知识: 是时候了解React Native了 从零学React Native之01创建第一个程序 从零学React Native之02状态机 本篇主要介绍页面导航 上一篇文章给 ...

  3. 从零学React Native之02状态机

    本篇文章首发于简书 欢迎关注 之前我们介绍了RN相关的知识: 是时候了解React Native了 从零学React Native之01创建第一个程序 本篇文章主要介绍下下面的知识: 1.简单界面的搭 ...

  4. 从零学React Native之04自定义对话框

    本篇主要介绍: 1. 自定义组件 2. Alert 对话框 自定义对话框 之前的我都是利用React Native提供的基础组件对它们进行排列组合, 其实自定义也很简单, 我们还是拿上一篇文章的例子进 ...

  5. 从零学React Native之14 网络请求

    通过HTTP或者HTTPS协议与网络侧服务器交换数据是移动应用中常见的通信方式. node-fetch是RN推荐的请求方式. React Native框架在初始化项目时, 引入了node-fetch包 ...

  6. 从零学React Native之12 组件的生命周期

    一个React Native组件从它被加载,到最终被卸载会经历一个完整的生命周期.所谓生命周期,就是一个对象从开始生成到最后消亡所经历的状态,理解生命周期,是合理开发的关键. ES6语法和之前的ES5 ...

  7. 从零学React Native之10Text

    在React Native开发中,所有需要显示的字符串文本都需要放置在Text或者Text的子组件中.虽然在之前的文章中多次使用了Text组件,但是Text组件还是值得专门学习的, 并没有想象中的那么 ...

  8. 从零学React Native之08Image组件

    开发过程中, 几乎每个项目都会用到图片. RN就是通过Image组件显示图片.既可以加载网络图片,也可以加载本地资源图片. Image组件必须在样式中声明图片的款和高.如果没有声明,则图片将不会被呈现 ...

  9. 从零学React Native之07View

    View 组件是React Native最基本的组件.绝大部分其他React Native 组件. View组件的颜色和边框 backgroundColor 键用来指定颜色. RN 0.19版本开始, ...

随机推荐

  1. tcmalloc jemalloc 和ptmalloc 对比

    ptmalloc 是glibc的内存分配管理 tcmalloc 是google的内存分配管理模块 jemalloc 是BSD的提供的内存分配管理 三者的性能对比参考从网上的一个图如下: 自己测试了一下 ...

  2. vue footer点击变色

    <header class="tab_nav"> <div v-for="(item,index) in tabNav" @click=&qu ...

  3. mysql命令行执行时不输出列名(字段名),直接显示字段对应的数值

    执行命令时加个-N参数就可以了 -N, –skip-column-names 比如说:mysql -uroot -p1234546 -N -e “select * from user;”

  4. Winform 奇怪的 英文字体错乱显示问题

    效果如图: 字体是Calibri 后来看了一下,我在vs设计器中为了预览效果定义了这些中文,然后在构造函数中将其改成英文,可能是已经为中文渲染出了位置?在改变就会冲突? 我的设计器 如何修改: 将vs ...

  5. CSS——浮动及应用&清除浮动

    浮动(float) 1.普通流(normal flow) 这个单词很多人翻译为 文档流 , 字面翻译 普通流 或者标准流都可以. 前面我们说过,网页布局的核心,就是用CSS来摆放盒子位置.如何把盒子摆 ...

  6. maven配置私服中可能遇到的问题

    文章目录 之前要写一个hsf的demo,maven的依赖是需要alibaba的私服的,所以出现了下面的错误. 具体参看另一篇文章:https://blog.csdn.net/dataiyangu/ar ...

  7. 学习笔记——CDQ分治

    再次感谢这位大佬的博客:https://www.cnblogs.com/ljc20020730/p/10395866.html CDQ分治,是一种在分治合并中计算前面值对后面答案的贡献的一种算法.今天 ...

  8. python list基本操作一

    a = [1,2,3,1,2,3] 一.删除元素 1.按索引删除: a.pop(1) # 删除第二个值 # in:[1,2,3,2] # out:[1,3,2] 返回值:被删除的元素,这个时候list ...

  9. spark1.0.2读取hbase(CDH0.96.1)上的数据

    基本环境: 我是在win7环境下,spark1.0.2,HBase0.9.6.1 使用工具:IDEA14.1, scala 2.11.6, sbt.我现在是测试环境使用的是单节点 1.使用IDEA创建 ...

  10. 996弱爆了,我还能12x12, 8116+8!

    Java技术栈 www.javastack.cn 优秀的Java技术公众号 来自长江日报 这些天"马云谈996"的话题火了 昨晚刘强东也在朋友圈发文 "8116+8!&q ...