JavaScript多并发问题如何处理


Posted in Javascript onOctober 28, 2015

经常在写代码的时候碰到这样的场景:页面初始化时显示loading页,同时启动多个ajax并发请求获取数据,当每个ajax请求返回时结束loading。

举个例子,一个下订单的页面,要查询常用地址信息、商品信息、地市信息…而这些请求都是异步的,希望等到所有数据加载完成后再允许用户操作。

要实现这个场景容易碰到的一个问题就是多并发怎么控制?下面是一些解决方法和思路:

并行改为串行

如果业务逻辑本身是串行的,但是提供的请求方式又是异步的,可以考虑此方法。
但本场景显然不是这种情况,这样做大大降低了页面性能,延长了加载速度。

回调

只适合并发数少的情况,多层嵌套回调会让代码的可读性大大降低

function async1(){
  //do sth...
}
function async2(){
  //do sth...
  async1();
}
async2();

ajax改为同步

如在jquery中将async参数设置为false

$.ajax({
  url:"/jquery/test1.txt",
  async:false
});

设置结束标识

简单一点的可以设置计数器,每完成一个异步函数加1,或者设置一个数组,每执行完一个异步函数更新数组。

回调计数

var cnt = 0;
function async1(){
  //do sth...
  callback();
}
function async2(){
  //do sth...
  callback();
}
function callback(){
  cnt++;
  if(2==cnt) console.log('都已执行完毕');
}

循环阻塞

var cnt = 0;
function async1(){
  //do sth...
  cnt++;
}
function async2(){
  //do sth...
  cnt++;
}
while(2>cnt){}

循环非阻塞

不建议过多使用,以免影响性能

var cnt = 0;
function async1(){
  //do sth...
  cnt++;
}
function async2(){
  //do sth...
  cnt++;
}
var interval = setInterval(function(){
  if(2===cnt){
    console.log('已执行完成');
    clearInterval(interval)
  }
}

第三方框架实现

jquery

目前我在项目中采用的方式

var d1 = $.Deferred();
var d2 = $.Deferred();
function async1(){
  d1.resolve( "Fish" );
}
function async2(){
  d2.resolve( "Pizza" );
}
$.when( d1, d2 ).done(function ( v1, v2 ) {
  console.log( v1 + v2 + '已完成');
});

以上内容是小编给大家介绍的关于JavaScript多并发问题如何处理的相关知识,希望对大家有所帮助。

Javascript 相关文章推荐
模拟多级复选框效果的jquery代码
Aug 13 Javascript
函数window.open实现关闭所有的子窗口
Aug 03 Javascript
Express使用html模板的详细代码
Sep 18 Javascript
vue中实现滚动加载更多的示例
Nov 08 Javascript
剖析Angular Component的源码示例
Mar 23 Javascript
vue 组件使用中的一些细节点
Apr 25 Javascript
基于vue-upload-component封装一个图片上传组件的示例
Oct 16 Javascript
关于vue利用postcss-pxtorem进行移动端适配的问题
Nov 20 Javascript
微信小程序开发之获取用户手机号码(php接口解密)
May 17 Javascript
JS实现前端动态分页码代码实例
Jun 02 Javascript
解决vue-router 嵌套路由没反应的问题
Sep 22 Javascript
vue element实现表格合并行数据
Nov 30 Vue.js
JS实现双击屏幕滚动效果代码
Oct 28 #Javascript
基于JavaScript如何实现私有成员的语法特征及私有成员的实现方式
Oct 28 #Javascript
jQuery实现滑动页面固定顶部显示(可根据显示位置消失与替换)
Oct 28 #Javascript
jquery实现的动态回到顶部特效代码
Oct 28 #Javascript
JavaScript如何调试有哪些建议和技巧附五款有用的调试工具
Oct 28 #Javascript
jQuery实现鼠标滑过链接控制图片的滑动展开与隐藏效果
Oct 28 #Javascript
使用Chart.js图表库制作漂亮的响应式表单
Oct 28 #Javascript
You might like
安健A254立体声随身听的分析与打磨
2021/03/02 无线电
很温暖很温暖的Lester Young
2021/03/03 冲泡冲煮
解决file_get_contents无法请求https连接的方法
2013/12/17 PHP
PHP弹出提示框并跳转到新页面即重定向到新页面
2014/01/24 PHP
ThinkPHP3.1新特性之G方法的使用
2014/06/19 PHP
PHP通过反射动态加载第三方类和获得类源码的实例
2015/11/27 PHP
JavaScript 滚轮事件使用说明
2010/03/07 Javascript
jquery 定位input元素的几种方法小结
2013/07/28 Javascript
Javascript单元测试框架QUnitjs详细介绍
2014/05/08 Javascript
jQuery 回调函数(callback)的使用和基础
2015/02/26 Javascript
JS实现三个层重叠点击互相切换的方法
2015/10/06 Javascript
基于JavaScript实现鼠标悬浮弹出跟随鼠标移动的带箭头的信息层
2016/01/18 Javascript
简单学习vue指令directive
2016/11/03 Javascript
Vue自定义事件(详解)
2017/08/19 Javascript
Vue中的字符串模板的使用
2018/05/17 Javascript
微信小程序实现下拉菜单切换效果
2020/03/30 Javascript
详解Node.js一行命令上传本地文件到服务器
2019/04/22 Javascript
解决vue 子组件修改父组件传来的props值报错问题
2019/11/09 Javascript
python选择排序算法的实现代码
2013/11/21 Python
简单的编程0基础下Python入门指引
2015/04/01 Python
用Python中的字典来处理索引统计的方法
2015/05/05 Python
Ruby元编程基础学习笔记整理
2016/07/02 Python
Python简单获取自身外网IP的方法
2016/09/18 Python
Python模块搜索路径代码详解
2018/01/29 Python
pycharm远程开发项目的实现步骤
2019/01/20 Python
Python中常见的数制转换有哪些
2020/05/27 Python
Pyqt助手安装PyQt5帮助文档过程图解
2020/11/20 Python
施华洛世奇美国官网:SWAROVSKI美国
2018/02/08 全球购物
Pandora西班牙官方商店:PandoraShop.es
2020/10/05 全球购物
什么是接口(Interface)?
2013/02/01 面试题
集体备课反思
2014/02/12 职场文书
触电现场处置方案
2014/05/14 职场文书
警察群众路线整改措施
2014/09/26 职场文书
2016年感恩教师节校园广播稿
2015/12/18 职场文书
python开发飞机大战游戏
2021/07/15 Python
恶魔之树最顶端的三颗果实 震震果实上榜,第一可以制造岩浆
2022/03/18 日漫