文档章节

jquery实现多任务

无知有趣
 无知有趣
发布于 2014/06/13 09:23
字数 720
阅读 197
收藏 0

在webapp目录下新建3个文件index.html, list.json(模拟查询请求结果)和task.json(模拟任务处理结果),访问index.html。

index.html:

<html>
<head>
<title>jQuery并发任务</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<style type="text/css">
#list td{border:1px solid #C0C0C0;}
#list th{border:1px solid #C0C0C0;background-color:#DCDCDC;}
#list tbody tr:hover{background-color:#e0e9f9;}
</style>
<script src="http://code.jquery.com/jquery-2.1.1.min.js"></script>
</head>
<body>

<table width="98%">
  <tr>
    <td align="left">
            并发:<input id="num" value="10" style="width:40px;"/>
     <input type="button" value="开始" id="btnS" onclick="begin();" />
     <input type="button" value="停止" id="btnE" onclick="stop();" disabled="true" />&nbsp;&nbsp;
     <br>
            进度:<span id="speed" style="font-size:200%;color:green;">0</span><span style="font-size:200%;">/</span><span id="total" style="font-size:200%;color:red;">0</span>
    </td>
  </tr>
  <tr>
    <td align="right">
            编号:<input id="taskID" value="" size=14/>
     <input type="button" value="查询" id="btnQ" onclick="query();"  />
    </td>
  </tr>
</table>
<br>

<table id="list" width="98%" cellspacing=0 style="border-collapse:collapse;">
<thead>
  <tr>
    <th nowrap width="5%"  align='center'>序号</th>
    <th nowrap width="15%" align='center'>编号</th>
    <th nowrap width="40%">名称</th>
    <th nowrap>处理结果</th>
  </tr>
</thead>
<tbody id="listB"></tbody>
</table>

</body>
</html>

<script language="javascript">
var tasks = [];     //列表json数组
var speed = 0;      //已完成
var doing = 0;      //处理中
var isStop= false;  //是否停止

function query(){
    $.ajax({
        type:       "POST",
        url:        "list.json",//TODO:列表查询action/a/b!list.action
        data:       "taskID="+$("#taskID").val(),
        dataType:   "json",
        async:      false,
        error:      function(request, msg) {
            alert('无法访问。');
        },
        success:    function(result){
            tasks = result;
            speed = 0;
            doing = 0;
            isStop= false;
            
            $("#speed").text(0);
            $("#total").text(tasks.length);
            $("#btnS").attr("disabled",false);
            $("#btnE").attr("disabled",true);
            
            var trs = "";
            for(var i=0;i<tasks.length;i++){
                trs += "<tr>";
                trs += "<td nowrap align='center'>"+(i+1)+"</td>";
                trs += "<td nowrap align='center'>"+tasks[i].TASK_ID+"</td>";
                trs += "<td nowrap id='vn"+i+"'>"+tasks[i].TASK_NAME+"</td>";
                trs += "<td id='vr"+i+"'></td>";
                trs += "</tr>";
            }
            $("#listB").html(trs);
        }
    });
}

function begin(){
  isStop = false;
  $("#btnS").attr("disabled",true);
  $("#btnE").attr("disabled",false);
  
  var num = Math.min($("#num").val(), tasks.length-doing);
  //遍历列表,发送num个,在每个处理返回结果时再次发送,保证num个处理中,直到结束
  for(var i=0; i<num; i++){
    startTask(doing++);
  }
}
function startTask(idx){
    if(idx >= tasks.length){
        $("#btnS").attr("disabled",true);
        $("#btnE").attr("disabled",true);
        return;
    }
    $.ajax({
        type:       "POST",
        url:        "task.json",//TODO:任务执行action/a/b!task.action
        data:       "pkTask="+tasks[idx].PK_TASK+"&taskID="+tasks[idx].TASK_ID,
        dataType:   "json",
        error:      function(request, msg) {
            $("#vr"+idx).text(msg);
        },
        beforeSend: function(){
            $("#vr"+idx).text("处理中...");
        },
        success:    function(result){
            $("#vr"+idx).text(result);
            
            speed++;
            $("#speed").text(speed);
            
            if(!isStop){
                startTask(doing++);
            }
        }
    });   
}

function stop(){
  isStop = true;
  $("#btnS").attr("disabled",false);
  $("#btnE").attr("disabled",true); 
}
</script>


list.json:

[{"PK_TASK":"1","TASK_ID":"ID-2014-0001","TASK_NAME":"任务1"},{"PK_TASK":"2","TASK_ID":"ID-2014-0002","TASK_NAME":"任务2"},{"PK_TASK":"3","TASK_ID":"ID-2014-0003","TASK_NAME":"任务3"},{"PK_TASK":"4","TASK_ID":"ID-2014-0004","TASK_NAME":"任务4"},{"PK_TASK":"5","TASK_ID":"ID-2014-0005","TASK_NAME":"任务5"},{"PK_TASK":"6","TASK_ID":"ID-2014-0006","TASK_NAME":"任务6"},{"PK_TASK":"7","TASK_ID":"ID-2014-0007","TASK_NAME":"任务7"},{"PK_TASK":"8","TASK_ID":"ID-2014-0008","TASK_NAME":"任务8"},{"PK_TASK":"9","TASK_ID":"ID-2014-0009","TASK_NAME":"任务9"},{"PK_TASK":"10","TASK_ID":"ID-2014-0010","TASK_NAME":"任务10"},{"PK_TASK":"11","TASK_ID":"ID-2014-0011","TASK_NAME":"任务11"},{"PK_TASK":"12","TASK_ID":"ID-2014-0012","TASK_NAME":"任务12"},{"PK_TASK":"13","TASK_ID":"ID-2014-0013","TASK_NAME":"任务13"},{"PK_TASK":"14","TASK_ID":"ID-2014-0014","TASK_NAME":"任务14"},{"PK_TASK":"15","TASK_ID":"ID-2014-0015","TASK_NAME":"任务15"}]


task.json:

"任务处理完成。"


© 著作权归作者所有

共有 人打赏支持
无知有趣
粉丝 13
博文 117
码字总数 33264
作品 0
北京
后端工程师
私信 提问
从零实现一个简易的jQuery框架之二—核心思路详解

如何读源码 整体框架甚是复杂,也不易读懂。但是若想要在前端的路上走得更远、更好,研究分析前端的框架无疑是进阶路上必经之路。但是庞大的源码往往让我们不知道从何处开始下手。在很长的时...

余大彬
08/08
0
0
30个创意出色的非常实用的jquery框架插件-(视觉大背景,瀑布流效果)

jQuery是在网页设计师和开发者最近的热门话题之一。人们使用它的广泛范围从个人博客到企业网站,目前流行的视觉大背景滚动效果,瀑布流图片阴影效果,图片缩放,动态标签复制,html5音频播放...

易达
2012/08/04
0
0
从零开始学 Web 之 jQuery(一)jQuery的概念,页面加载事件

大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:http://www.cnblogs.com/lvonve/ CSDN...

fengdaoting
07/04
0
0
jQuery学习笔记--选择器和事件

以下内容参考 W3school 简书 你要是问我什么是jQuery 那可以这么两句话概括: jQuery 是一个 JavaScript 库。 jQuery 极大地简化了 JavaScript 编程。 要学jQuery最好有点javaScript的基础 ...

codingcoge
05/17
0
0
谈谈 jQuery 中的防冲突(noConflict)机制

许多的 JS 框架类库都选择使用 $ 符号作为函数或变量名,jQuery 是其中最为典型的一个。在 jQuery 中,$ 符号只是 window.jQuery 对象的一个引用,因此即使 $ 被删除,window.jQuery 依然是保...

i33
2013/03/13
0
0

没有更多内容

加载失败,请刷新页面

加载更多

CAS和AQS

CAS(Compare And Swap) 什么是CAS CAS(Compare And Swap),即比较并交换。是解决多线程并行情况下使用锁造成性能损耗的一种机制。 CAS是一种系统原语,原语属于操作系统用语范畴,是由若干条...

狼王黄师傅
15分钟前
1
0
Python利用pandas处理Excel数据的应用

Python利用pandas处理Excel数据的应用 最近迷上了高效处理数据的pandas,其实这个是用来做数据分析的,如果你是做大数据分析和测试的,那么这个是非常的有用的!!但是其实我们平时在做自动化...

上官夏洛特
29分钟前
1
0
100:代码管理平台svn

1:代码管理平台:代码版本管理工具,工作中用于代码更新,代码发布统计,代码版本控制;(频繁更新代码的版本记录),方便查阅历史变更,协同开发及合并; 版本管理工具发展: cvs(编码兼容不太好)...

芬野de博客
29分钟前
0
0
Linux学习-1101(rsync下、log、screen)

10.32/10.33 rsync通过服务同步 10.34 linux系统日志 10.35 screen工具 一、 rsync通过服务同步 rsync 通过服务的方式同步,首先需要开启一个服务。它是C/S架构,开启rsync服务,默认端口是8...

wxy丶
36分钟前
1
0
使用jpmml-sparkml-executable生成PMML模型文件

加载依赖的jar包通过./spark-shell --jars ./jpmml-sparkml-executable-1.2.13.jar 启动spark import org.apache.spark.ml.classification.LogisticRegressionimport org.apache.spark.m......

KYO4321
39分钟前
1
1

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部