返回旧版| 微信建站| 建站之家论坛| 我要建站 | 建站学习 | 加入收藏
Ajax入门当前位置:首页 > HTML教程 > Ajax入门 > 正文

使用AJAX技术实现网页无刷新进度条显示

发布时间:2013-08-28 10:07:00   来源:   点击:

    在网页中实现页面无刷新的进度条显示不是一件很麻烦的事情,但如果这个进度条要能准确反映当前事务或者复杂逻辑的执行进度,那么却并不是一件容易的事情,目前AJAX技术流行,所以本文作者试想通过AJAX来实现网页准确进度条,以銄读者。
    首先应该想一个问题,复杂事务或者事务逻辑如果不按线程方式运行,运行在JAVA运行中根本无法跳过复杂事务去处理进度显示,所以我们这边很自然的想到复杂事务或者业务逻辑用多线程实现。
    再想另一个问题,事务处理应该需要网页上的一系列参数信息的,那么如何获取这些参数呢,这个似乎容易想到,传一个HttpServletRequest过去就可以了。
为了进度条公用,所有的复杂事务处理都应该实现同一个接口或者抽象类,我这里用了一个接口,如下:

  1. public interface IprogressBar { 
  2.   public void execute(HttpServletRequest req,String pbid);//执行复杂事务 
  3. 用一个实现多线程的抽象类,如下: 
  4. public abstract class AbstractProgressBar extends TimerTask implements IprogressBar { 
  5.  private HttpServletRequest request; 
  6.  private String pbid; 
  7.   public AbstractProgressBar(){ 
  8.  } 
  9.  //子类必须重载这个函数 
  10.  public abstract void execute(HttpServletRequest req, String pbid);  
  11.  public void run() { 
  12.   execute(request,pbid);  
  13.  } 
  14.  public void setRequest(HttpServletRequest req){ 
  15.   
  16.  
  17.   this.request=req; 
  18.  } 
  19.  public void setPbid(String pbid){ 
  20.   this.pbid=pbid; 
  21.  } 
  22. 设计到具体项目不便给出代码,这里我另外写了一个测试类,也就是执行复杂事务处理的类,如下: 
  23. public class TestPB extends AbstractProgressBar{ 
  24.  public void execute(HttpServletRequest req, String pbid) {   
  25.   String sql="insert into temp_table(idx)values(?)"
  26.   int pid=Integer.parseInt(pbid); 
  27.   ProgressBar pb=new ProgressBar(pid,300,0,1); 
  28.   //模拟大事务 
  29.   for(int i=0;i<300;i++){ 
  30.    DbUtils.executeUpdate(sql,new Object[]{new Integer(i)}); 
  31.   //控制进度  
  32. pb.stepIt(); 
  33.   } 
  34.  } 
  35. 接着利用AJAX技术来实现网页的无刷新进度条实现,代码如下: 
  36. <%@ page contentType="text/html;charset=UTF-8"%> 
  37.   
  38.   
  39.   
  40.  
  41. <title>无刷新页面进度条测试</title> 
  42. <STYLE TYPE="text/css"> 
  43. <!-- 
  44. BODY {OVERFLOW:scroll;OVERFLOW-X:hidden} 
  45. .DEK {POSITION:absolute;VISIBILITY:hidden;Z-INDEX:200;} 
  46. //--> 
  47. </STYLE> 
  48. <script type="text/javascript"> 
  49. var xmlHttp; 
  50. var pbid;//进度条ID 
  51. function createXMLHttpRequest(){ 
  52. if (window.ActiveXObject) { 
  53. xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); 
  54. else if (window.XMLHttpRequest) { 
  55. xmlHttp = new XMLHttpRequest(); 
  56. function checkDiv() { 
  57. var progress_bar = document.getElementById("progressBar"); 
  58. if (progress_bar.style.visibility != "visible") { 
  59. progress_bar.style.visibility = "visible"
  60. }else 
  61. progress_bar.style.visibility = "hidden"
  62. function go() { 
  63. createXMLHttpRequest(); 
  64. checkDiv(); 
  65. var url = "../servlet/ProgressBarServlet?task=create&impcls=blogcn.pb.imp.TestPB";//其中blogcn.pb.imp.TestPB是复杂事务的实现类 
  66.   
  67.  
  68. var button = document.getElementById("go"); 
  69. button.disabled = true
  70. xmlHttp.open("GET", url, true); 
  71. xmlHttp.setRequestHeader("Content-Type", "text/xml;charset=gb2312"); 
  72. xmlHttp.onreadystatechange = goCallback
  73. xmlHttp.send(null); 
  74. function goCallback(){ 
  75. if (xmlHttp.readyState==4)  
  76.  if (xmlHttp.status==200) { 
  77.  pbid=xmlHttp.responseXML.getElementsByTagName("pbid")[0].firstChild.data; 
  78.   setTimeout("pollServer()", 2000); 
  79.  } 
  80. function pollServer() { 
  81. createXMLHttpRequest(); 
  82. var url = "../servlet/ProgressBarServlet?task=poll&pbid="+pbid; 
  83. xmlHttp.open("GET", url, true); 
  84. xmlHttp.onreadystatechange = pollCallback
  85. xmlHttp.send(null); 
  86. function pollCallback(){ 
  87. if (xmlHttp.readyState == 4) { 
  88. if (xmlHttp.status == 200) { 
  89.  var percent_complete = 
  90.  xmlHttp.responseXML 
  91.  .getElementsByTagName("percent")[0].firstChild.data;  
  92.  if (percent_complete < 100) { 
  93.      PB1.pos=percent_complete
  94.         PB1.Update();     
  95.   setTimeout("pollServer()", 2000); 
  96.  } else { 
  97.      PB1.pos=100
  98.         PB1.Update(); 
  99.   document.getElementById("go").disabled = false
  100.  } 
  101.  } 
  102.   
  103.   
  104.           <input type="button" value="执行大事务" id="go" onclick="go();"/> 
  105.     <DIV id="progressBar"> 
  106.        <script language="javascript"> 
  107.      var PB1=new TProgressBar("myPB1",220,180,375,20); 
  108.      PB1.Create(); 
  109.      PirateCount=100
  110.      PID=PirateCount-2; 
  111.      PB1.Reposition(); 
  112.      PB1.max=PID

 

版权所有:郑州腾石网络科技有限公司 备案信息:豫ICP备18019117号
站长QQ:2863868475 业务合作咨询:15137100750(同微信)
本站所有投放的广告是有其他网站提供,不代表本站立场,同时网站首页广告位对外出租详情咨询本站站长!同时欢迎广大站长加入个人建站团队
  • 建站客服
  • CMS仿站
  • CMS学习
  • 技术交流群:336572814