ReactNative踩坑日志——使用async/await语法解决网络请求的异步导致的指令执行顺序错乱问题
转载请注明原文地址:
ReactNative的fetch是天然的异步请求,因此,如果你在一个代码块中使用了fetch,那么在执行的时候程序不会等待网络响应结束才执行下一条代码,而是会直接按顺序执行完整个代码块。而这样的话,某些具有先后条件的代码就会存在结果混乱等问题。
比如:一个登录方法
doLogin(){
//1:根据输入的工号、密码进行登录
fetch(this.hostIP + "/login?user="+this.user+"&password="+this.password).then((response) => response.json())
.then((json) => {
//处理响应
this.isLogin = true
}).catch((error) => {
alert("登录失败,请检查网络连接!")
})
//2:根据登录结果控制跳转
if(isLogin){
this.props.navigation.navigate('Menu')
}else{
alert("登录失败")
}
}
理论上,我们的执行逻辑是先用fetch进行登录,然后根据后台返回结果,控制跳转或弹出失败提示。
然而上述代码在执行时就会出现一旦点击登录按钮就会立刻弹出“登录失败”的提示,等再次点击登录按钮,却又跳转到了主页面。
原因就是因为,第一次点击登录按钮时,fetch异步执行,结果还没有返回,而RN已经执行到下面的if-else代码块了,因此登录失败。
而再次点击时,上一次的fetch结果已经返回了,所以if-else语句就会根据上一次点击时的fetch结果作为判断条件来执行了。
那么,怎么解决呢?ES7提供了终极异步解决方案——async/await语法
我们可以在定义一个含有异步操作的方法时,在其前面加上 async 关键字,标示该方法是异步方法;
而在方法中,使用 await 关键字修饰异步操作,该关键字的作用时:等待该语句执行完毕才执行下一条代码。
这样,我们在具有先后条件限制的代码块中,用await关键字修饰其中的异步代码,即可保证按照顺序执行,从而得到正确的结果了。
改进后的登录方法:
async doLogin(){
//1:根据输入的工号、密码进行登录
await fetch(this.hostIP + "/login?user="+this.user+"&password="+this.password).then((response) => response.json())
.then((json) => {
//处理响应
this.isLogin = true
}).catch((error) => {
alert("登录失败,请检查网络连接!")
})
//2:根据登录结果控制跳转
if(isLogin){
this.props.navigation.navigate('Menu')
}else{
alert("登录失败")
}
}
ReactNative踩坑日志——使用async/await语法解决网络请求的异步导致的指令执行顺序错乱问题的更多相关文章
- ReactNative踩坑日志——OnPress随着render()执行被自动调用?
在ReactNative中,Text.Button以及其他Touchable包装成的可点击控件,都可以通过onPress属性为其指定点击时的响应函数. 在有些情况下,我们会把这些点击函数先定义好,然后 ...
- ReactNative踩坑日志——代码执行方式(面向对象)
在ReactNative中,是以面向对象的方式执行代码的.处于同一{}內的代码以对象的形式执行,也就是说,程序虽然会自上而下执行代码,但是它会保证当前整个代码块內的语句执行完毕才执行下一代码块. 举个 ...
- ReactNative踩坑日志——函数绑定this
ES6语法定义的函数没有自动绑定this,所以在函数中使用了 this.xxx 就会报错,因为没有把类实例等this传进函数中. 有两种方法绑定this: 法1:在构造函数中为其他函数绑定this c ...
- ReactNative踩坑日志——如何实现删除scrollview中的视图
在reactNative中,页面是根据state值的变化来重新渲染的.因此,传统的前端开发中通过 id 来移除一个页面元素的做法在这里不适用. 一般,我们是通过遍历数组或map来渲染出scrollvi ...
- ReactNative踩坑日志——fetch如何向服务器传递参数
一:简单参数 简单的参数,我们可以使用手动拼接的方式传递. 格式为: fetch(url?key1=val1&key2=val2&...).then((response) => ...
- ReactNative踩坑日志——页面跳转之——Undefined is not an Object(evaluating this2.props.navigation.navigate)
页面跳转时,报 Undefined is not an Object(evaluating this2.props.navigation.navigate) 出错原因:在一个页面组件中调用了另一个组 ...
- 重新认识 async/await 语法糖
提起.Net中的 async/await,相信很多.neter 第一反应都会是异步编程,其本质是语法糖,但继续追查下去,既然是语法糖,那么经过编译之后,真正的代码是什么样的,如何执行的?带着这些疑问, ...
- Python PEP 492 中文翻译——协程与async/await语法
原文标题:PEP 0492 -- Coroutines with async and await syntax 原文链接:https://www.python.org/dev/peps/pep-049 ...
- C#Framework4.0支持异步async/await语法
由于用户使用的是XP系统,但是程序里异步都是通过async/await代码来实现的,然而async/await需要Framework4.5版本才可以,而XP系统最高只能支持到Framework4.0, ...
随机推荐
- C# 异步编程Task整理(一)
一.简介 .Net Framework 4.0新增了一个System.Threading.Tasks命名空间,它包含的类提供了任务的相关操作.使用任务不仅可以获得一个抽象层,还能对底层线程进行很多统一 ...
- protobuf 语法简介
protobuf 语法简介 1.基本语义 在.proto文件中,最基本的数据类型为message,如其定义所示,由message引导,之后是message类型的名字,之后是由{}包含的各个域(fiel ...
- Netty Message RefCount
ByteBuf is always reference counted To control the life cycle of a ByteBuf in a more predictable way ...
- 【ContestHunter】【弱省胡策】【Round6】
KMP/DP+树链剖分+线段树/暴力 今天考的真是……大起大落…… String QwQ题意理解又出错了……(还是说一开始理解了,后来自己又忘了为什么是这样了?) 反正最后的结果就是……我当成:后面每 ...
- 使用Log4j将程序日志实时写入Kafka(转)
原文链接:使用Log4j将程序日志实时写入Kafka 很多应用程序使用Log4j记录日志,如何使用Kafka实时的收集与存储这些Log4j产生的日志呢?一种方案是使用其他组件(比如Flume,或者自己 ...
- 数学图形(1.48)Cranioid curve头颅线
这是一种形似乎头颅的曲线.这种曲线让我想起读研的时候,搞的医学图像三维可视化.那时的原始数据为脑部CT图像.而三维重建中有一种方式是面绘制,是将每一幅CT的颅骨轮廓提取出来,然后一层层地罗列在一起,生 ...
- go语言之进阶篇Ticker的使用
Ticker是一个定时触发的计时器,它会以一个间隔(interval)往channel发送一个事件(当前时间),而channel的接收者可以以固定的时间间隔从channel中读取事件. 1.Ticke ...
- 如何感性地理解EM算法?
https://www.jianshu.com/p/1121509ac1dc 如果使用基于最大似然估计的模型,模型中存在隐变量,就要用EM算法做参数估计.个人认为,理解EM算法背后的idea,远比看懂 ...
- Tensorflow动态seq2seq使用总结(r1.3)
https://www.jianshu.com/p/c0c5f1bdbb88 动机 其实差不多半年之前就想吐槽Tensorflow的seq2seq了(后面博主去干了些别的事情),官方的代码已经抛弃原来 ...
- String escape/unescape into XML
Is there any C# function which could be used to escape and un-escape a string, which could be used t ...