赞
踩
数据持久化就是指应用程序将某些数据存储在手机存储空间中。
RN框架为开发者提供了 AsyncStorage API,开发者可以利用它将任意“字符串键值对”保存到存储空间中。
它是简单的,异步的。用它可以取代Android的sharedperference和ios的NSUserDefault。
AsyncStorage存储的数据对该RN应用全局都是可以访问的,只需要知道通过它增删改查数据就可以了。
- static object setItem(key, value,aCallBack)
代码如下:
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-
-
-
-
- doSomething(error){
-
-
- if(error!=
-
- null){
-
- //如发生错误 处理
-
-
- console.log(
-
- 'error message:'+error.message);
-
-
- return;
- }
-
-
- // 执行保存成功的操作
-
-
- console.log(
-
- "name保存成功!");
- }
-
-
-
- 作者:于连林520wcf
- 链接:https://www.jianshu.com/p/55263b414090
- 來源:简书
- 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-
-
-
- // 构造
-
-
- 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);
- }
- };
-
-
-
- 作者:于连林520wcf
- 链接:https://www.jianshu.com/p/55263b414090
- 來源:简书
- 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
- // 构造
- 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机制还可以通过下面的方式捕获异常。
- 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{
- //异常不是数组,有可能是成功操作的处理函数抛出的异常
- //...
- }
- });
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?)
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-
-
-
-
- // 构造
-
-
- 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);
- }
- };
-
-
-
- 作者:于连林520wcf
- 链接:https://www.jianshu.com/p/55263b414090
- 來源:简书
- 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
-
-
-
- doSomething(error){
-
-
- if(error!=
-
- null){
-
- //如发生错误 处理
-
-
- console.log(
-
- 'error message:'+error.message);
-
-
- return;
- }
-
-
- // 执行保存成功的操作
-
-
- console.log(
-
- "name保存成功!");
- }
-
-
-
- 作者:于连林520wcf
- 链接:https://www.jianshu.com/p/55263b414090
- 來源:简书
- 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
doSomething(error){
if(error!=
null){
//如发生错误 处理
console.log(
'error message:'+error.message);
return;
}
// 执行保存成功的操作
console.log(
"name保存成功!");
}
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
// 构造
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);
}
};
作者:于连林520wcf
链接:https://www.jianshu.com/p/55263b414090
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。