JS+WCF实现进度条实时监测数据加载量的方法详解


Posted in Javascript onDecember 19, 2017

本文实例讲述了JS+WCF实现进度条实时监测数据加载量的方法。分享给大家供大家参考,具体如下:

背景

由于项目中需要导入大量数据到memcache中

需要用WCF调取11万条数据,由于那边多级联查和排序,所以比较慢(1分钟左右)

同时这边需要对数据进行处理,合并成2万条数据,然后存储,需要一定时间(也是1分钟左右)

总之,完成这个数据导入一共需要1分30秒左右

这时候,需要一个进度条来实时监测完成的数据量

(之前用的是一个动态图,不能知道程序目前的完成量,甚至不知道它是不是卡住了,只能等着)

功能

1.开辟线程,用于加载数据,处理数据
2.前台实时读取后台数据,并显示

代码

view-html

@* 数据准备进度条 *@
  <div id="container">
    <div class="content">
      <h1>数据准备</h1>
    </div>
    <!-- Progress bar -->
    <div id="progress_bar" class="ui-progress-bar ui-container">
      <div class="ui-progress" style="width: 3%;">
        <span class="ui-label" style="display: none;">完成量<b class="value">3%</b></span>
      </div>
    </div>
    <!-- /Progress bar -->
    <div class="content" id="main_content" style="display: none;">
      <p>数据准备完成!</p>
    </div>
  </div>

view-js

$(function () {
    $('#initialization').click(function () {
      $.messager.confirm('提示', '是否要进行数据初始化?', function (r) {
        if (!r) {
          return;
        }
        else {
          $('#container').show();
          var t1 = window.setInterval(process_bar, 1500);
        }
      });
    });
});
function process_bar() {
    $.ajax({
      type: "POST",
      async: true,
      url: "/Paper/LoadData",
      success: function (result) {
        $('#progress_bar .ui-progress').animateProgress(result);
        if (result =="100") {
          $('#main_content').slideDown();
          $('#fork_me').fadeIn();
          setTimeout(function () { $('#container').hide();; }, 1500);
          window.clearInterval(t1);
        }
      }
    })
}

controller

static bool flag = true;
public int LoadData()
{
  int result = Ipaperbll.LoadDataAmount();
  if (flag)
  {
    Thread thread = new Thread(new ThreadStart(ThreadLoadData));
    thread.Start();
    flag = false;
  }
  return result;
}
private void ThreadLoadData()
{
  Ipaperbll.initializeData();
}

后台

static int load_data_amount;//当前数据准备量
public bool initializeData()
{
  bool flag = false;  //定义返回值
  //获得数据
  //code....code ....code....
  load_data_amount = 5;//完成工作量
  int page = 0;
  int amount = 50000;//一次获取数据量不能超过10万
  while (page * amount == list.Count)
  {
    //code....code ....code....
    load_data_amount = load_data_amount + 5;
  }
  load_data_amount = 50;//读取数据默认的工作量
  double totalamount = list.Count();
  foreach (var item in list)
  {
    //code....code ....code....
    load_data_amount = Convert.ToInt32((1 - (totalamount--) / double.Parse(list.Count().ToString())) * 50) + 50;//根据数据改变的完成工作量
  }
  load_data_amount = 100;//完成工作量
  flag = true;
  return flag;
}
//返回当前准备数据量
public int LoadDataAmount() {
  return load_data_amount;
}

问题 & 解决

1.进度条生成

解决:使用网上的demo,css+js可以动态生成,改变数据即可

2.线程问题

解决:开始是监测使用线程,后来改成处理数据使用线程

3.实时监测问题

解决:处理数据使用线程自动运行,前台使用ajax不断查询后台的一个变量load_data_amount

4.ajax报错问题

注意是返回值的类型,以及是result还是result.d,不同情况下是不一样的

5.数据类型问题

解决:读取数据完成的百分比,是用 完成量/所有量 得到的,这里的数一直算不对,是因为int类型承受不住11万的运算以及之后的小数,用double和float可以

小结

本来想着开个线程,加个变量,返回前台,加一个进度条,读取变量就OK了

但是中间的这个MVC,这个Spring,这个接口,之前的方法各种不好使,以及在它们下面的运算,ajax……一个一个分开解决,最后还是解决了

分而治之,逐个解决,测试就好

另外,框架和合作在带来便利的同时,中间的限制和bug也会让你的效率下降

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
jQuery 入门级学习笔记及源码
Jan 22 Javascript
jqGrid jQuery 表格插件测试代码
Aug 23 Javascript
ajax java 实现自动完成功能
Dec 19 Javascript
JS+CSS实现可拖拽的漂亮圆角特效弹出层完整实例
Feb 13 Javascript
JavaScript中常见获取元素的方法汇总
Mar 04 Javascript
AngularJS基础知识笔记之过滤器
May 10 Javascript
js实现鼠标移到链接文字弹出一个提示层的方法
May 11 Javascript
JavaScript代码判断输入的字符串是否含有特殊字符和表情代码实例
Aug 17 Javascript
Vue代码分割懒加载的实现方法
Nov 23 Javascript
angular-tree-component的使用详解
Jul 30 Javascript
vue组件添加事件@click.native操作
Oct 30 Javascript
适合后台管理系统开发的12个前端框架(小结)
Jun 29 Javascript
jquery自定义显示消息数量
Dec 19 #jQuery
基于Vue开发数字输入框组件
Dec 19 #Javascript
jquery实现侧边栏左右伸缩效果的示例
Dec 19 #jQuery
从setTimeout看js函数执行过程
Dec 19 #Javascript
mongoose更新对象的两种方法示例比较
Dec 19 #Javascript
jquery中done和then的区别(详解)
Dec 19 #jQuery
JavaScript实现AOP详解(面向切面编程,装饰者模式)
Dec 19 #Javascript
You might like
提问的智慧(2)
2006/10/09 PHP
php基础知识:类与对象(2) 自动加载对象
2006/12/13 PHP
php REMOTE_ADDR之获取访客IP的代码
2008/04/22 PHP
php获取表单中多个同名input元素的值
2014/03/20 PHP
PHP实现把文本中的URL转换为链接的auolink()函数分享
2014/07/29 PHP
jQeury淡入淡出需要注意的问题
2010/09/08 Javascript
10个基于Jquery的幻灯片插件教程
2010/10/29 Javascript
在JavaScript中监听IME键盘输入事件
2011/05/29 Javascript
JS实现图片放大镜效果的方法
2015/02/27 Javascript
JavaScript将字符串转换成字符编码列表的方法
2015/03/19 Javascript
Javascript代码实现仿实例化类
2015/04/03 Javascript
使用CSS+JavaScript或纯js实现半透明遮罩效果的实例分享
2016/05/09 Javascript
深入解析JavaScript中的立即执行函数
2016/05/21 Javascript
AngularJS入门教程之静态模板详解
2016/08/18 Javascript
判断js的Array和Object的实现方法
2016/08/29 Javascript
微信小程序城市定位的实现实例(获取当前所在国家城市信息)
2017/05/17 Javascript
Angular2实现的秒表及改良版示例
2019/05/10 Javascript
小程序绑定用户方案优化小结
2019/05/15 Javascript
prettier自动格式化去换行的实现代码
2020/08/25 Javascript
javascript实现拼图游戏
2021/01/29 Javascript
python使用Tkinter显示网络图片的方法
2015/04/24 Python
Python变量和数据类型详解
2017/02/15 Python
Python中的defaultdict与__missing__()使用介绍
2018/02/03 Python
利用python画出折线图
2018/07/26 Python
Python第三方库face_recognition在windows上的安装过程
2019/05/03 Python
Django 创建/删除用户的示例代码
2019/07/24 Python
CSS3属性 line-clamp控制文本行数的使用
2020/03/19 HTML / CSS
英国男士时尚购物网站:Stuarts London
2017/10/22 全球购物
在C语言中实现抽象数据类型什么方法最好
2014/06/26 面试题
入职担保书范文
2014/05/21 职场文书
专业见习报告范文
2014/11/03 职场文书
2015年度物业公司工作总结
2015/04/27 职场文书
2016个人先进事迹材料范文
2016/03/01 职场文书
Nginx的反向代理实例详解
2021/03/31 Servers
python 离散点图画法的实现
2022/04/01 Python
Ruby GDBM操作简介及数据存储原理
2022/04/19 Ruby