浅谈JavaScript异步编程

网络编程 2021-07-04 19:20www.168986.cn编程入门
本文主要介绍了javascript的异步编程相关知识。具有一定的参考价值,狼蚁网站SEO优化跟着长沙网络推广一起来看下吧

在一年前初学js的时候,看过很多关于异步编程的讲解。由于实践经验少,没有办法理解的太多,太理论的东西也往往是看完就忘。

经过公司的三两个项目的锻炼,终于对js异步编程有了比较具体的理解。但始终入门较浅,在这里就当是给自己一个阶段性的。

在异步编程中,一条语句的执行不能依赖上一条语句执行完毕的结果,因为无法预测一条语句什么时候执行完毕,它与代码顺序无关,语句是并发执行的。

例如以下代码

$.get($C.apiPath+'ucenter/padCharge/findMember',{id:memberId},function(data){
  if(data.error){
    layer.close(memberLayer);
    padInOut(padId,memberId);
    allPads();
  }
});

这三句在语境中的作用是,在完成某个ajax访问并成功获得数据之后,关闭某个弹层(1),执行padInOut函数(2),执行allPads函数(3);(1)的顺序无所谓,我希望(3)在(2)之后执行,这几句代码无法达到我希望的结果,因为三个函数是执行的,allPads无法等待padInOut执行完毕之后再执行,所以结果会出错。

我采取的解决方法是回调函数在padInOut函数定义加入回调函数,如下

function padInOut(padId,memberId,callback){
     $F.POSTLoading($C.apiPath + 'ucenter/padCharge/padInOut',{id:padId,memberId:memberId},function(data){
         if(callback)callback()
     });
 }; 

当方法执行完毕并且回调函数存在时,执行回调函数。此时函数执行时通过传参即可达到目的

padInOut(padId,memberId,allPads)

回调函数是js异步编程经常会用到的方法。使用回调函数存在不好的地方,即会造成回调地狱。所以es新标准出来也不断寻求解决回调的方案。这是后话,本篇写到这里。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望多多支持狼蚁SEO!

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by