欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用AJAX實(shí)現(xiàn)Web頁(yè)面進(jìn)度條的實(shí)例分享

 更新時(shí)間:2016年05月06日 16:59:58   作者:Arison  
這篇文章主要介紹了使用AJAX實(shí)現(xiàn)Web頁(yè)面進(jìn)度條的實(shí)例分享,利用AJAX的異步來(lái)顯示服務(wù)器端的處理進(jìn)度是當(dāng)下比較流行的做法,需要的朋友可以參考下

在應(yīng)用程序的安裝和下載過(guò)程中,進(jìn)度條的使用已經(jīng)是非常普遍了。進(jìn)度條可以用來(lái)表識(shí)項(xiàng)目的完成進(jìn)度,可以用百分比或數(shù)字表示,可以水平放置。利用Ajax技術(shù)創(chuàng)建進(jìn)度條,功能顯得更加強(qiáng)大的快捷。
現(xiàn)在創(chuàng)建一個(gè)實(shí)例,以演示使用Ajax技術(shù)實(shí)現(xiàn)進(jìn)度條。該實(shí)例同樣可以分為客戶端代碼和服務(wù)端代碼。
 
1,服務(wù)端代碼   
服務(wù)端代碼主要實(shí)現(xiàn)一句客戶端的請(qǐng)求信息,返回相應(yīng)的百分比數(shù)字。打開(kāi)記事本,輸入下列代碼:

<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %> 
<%! 
int counter = 1;//注意:多用戶將共享此變量,此進(jìn)度條只適合單用戶 
%> 
<% 
 String task = request.getParameter("task"); 
  String res = ""; 
   
  if (task.equals("create")) { 
   res = "1"; 
   counter = 1; 
  } 
  else { 
   String percent = ""; 
   switch (counter) { 
    case 1: percent = "10"; break; 
    case 2: percent = "23"; break; 
    case 3: percent = "35"; break; 
    case 4: percent = "51"; break; 
    case 5: percent = "64"; break; 
    case 6: percent = "73"; break; 
    case 7: percent = "89"; break; 
    case 8: percent = "100"; break; 
   } 
   counter++; 
     
   res = "<percent>" + percent + "</percent>"; 
  } 
   
  // PrintWriter out = response.getWriter(); 
  response.setContentType("text/xml"); 
  response.setHeader("Cache-Control", "no-cache"); 
  out.println("<response>"); 
  out.println(res); 
  out.println("</response>"); 
  out.close();  
%> 


 
將上述代碼保存,名稱為ProgressBar.jsp。在該文件中,聲明了一個(gè)變量counter,并賦值為1,該變量是進(jìn)度條返回百分比數(shù)字的依據(jù)。在下面使用request對(duì)象獲取客戶端傳送的變量task的值,如果該值為create,表示需要重新創(chuàng)建進(jìn)度條,并設(shè)定counter的值為1;如果task不是create,則會(huì)依據(jù)counter的值返回百分比數(shù)字,完成一次操作,counter值加1。
 
2,客戶端代碼
本實(shí)例的客戶端代碼主要實(shí)現(xiàn)依據(jù)返回百分比數(shù)字顯示進(jìn)度條的狀態(tài)。打開(kāi)記事本,輸入下列代碼:
<html> 
 <head> 
 <title>JSP+Ajax 進(jìn)度條</title> 
 <script type="text/javascript"> 
  var xmlHttp; 
  var bar_color = 'blue'; 
  var span_id = "yellow"; 
  var clear = " " 
 
  function createXMLHttpRequest() { 
   if (window.ActiveXObject) { 
    xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); 
   } 
   else if (window.XMLHttpRequest) { 
    xmlHttp = new XMLHttpRequest();     
   } 
  } 
 
  function go() { 
   createXMLHttpRequest(); 
   checkDiv(); 
   var url = "ProgressBarJsp.jsp?task=create"; 
   xmlHttp.open("GET", url, true); 
   xmlHttp.onreadystatechange = goCallback; 
   xmlHttp.send(null); 
  } 
 
  function goCallback() { 
   if (xmlHttp.readyState == 4) { 
    if (xmlHttp.status == 200) { 
     setTimeout("pollServer()", 2000); 
    } 
   } 
  } 
   
  function pollServer() { 
   createXMLHttpRequest(); 
   var url = "ProgressBarJsp.jsp?task=poll"; 
   xmlHttp.open("GET", url, true); 
   xmlHttp.onreadystatechange = pollCallback; 
   xmlHttp.send(null); 
  } 
   
  function pollCallback() { 
   if (xmlHttp.readyState == 4) { 
    if (xmlHttp.status == 200) { 
     var percent_complete = xmlHttp.responseXML.getElementsByTagName("percent")[0].firstChild.data; 
      
     var index = processResult(percent_complete); 
     for (var i = 1; i <= index; i++) { 
      var elem = document.getElementById("block" + i); 
      elem.innerHTML = clear; 
 
      elem.style.backgroundColor = bar_color; 
      var next_cell = i + 1; 
      if (next_cell > index && next_cell <= 9) { 
       document.getElementById("block" + next_cell).innerHTML = percent_complete + "%"; 
      } 
     } 
     if (index < 9) { 
      setTimeout("pollServer()", 2000); 
     } else { 
      document.getElementById("complete").innerHTML = "網(wǎng)站已完成加載!"; 
     } 
    } 
   } 
  } 
   
  function processResult(percent_complete) { 
   var ind; 
   if (percent_complete.length == 1) { 
    ind = 1; 
   } else if (percent_complete.length == 2) { 
    ind = percent_complete.substring(0, 1); 
   } else { 
    ind = 9; 
   } 
   return ind; 
  } 
 
  function checkDiv() { 
   var progress_bar = document.getElementById("progressBar"); 
   if (progress_bar.style.visibility == "visible") { 
    clearBar(); 
    document.getElementById("complete").innerHTML = ""; 
   } else { 
    progress_bar.style.visibility = "visible" 
   } 
  } 
   
  function clearBar() { 
   for (var i = 1; i < 10; i++) { 
    var elem = document.getElementById("block" + i); 
    elem.innerHTML = clear; 
    elem.style.backgroundColor = "white"; 
   } 
  } 
 </script> 
 </head> 
 <body onload="go();"> 
 <h1 align=center>網(wǎng)站正在加載中,請(qǐng)稍候</h1> 
 
 <p> 
 <table align="center"> 
  <tbody> 
   <tr><td> 
    <div id="progressBar" style="padding:2px;border:solid yellow 2px;visibility:hidden"> 
     <span id="block1"> </span> 
     <span id="block2"> </span> 
     <span id="block3"> </span> 
     <span id="block4"> </span> 
     <span id="block5"> </span> 
     <span id="block6"> </span> 
     <span id="block7"> </span> 
     <span id="block8"> </span> 
     <span id="block9"> </span> 
    </div> 
   </td></tr> 
   <tr><td align="center" id="complete"></td></tr> 
  </tbody> 
 </table> 
 </body> 
</html> 

將上述代碼保存,名稱為JspprogressBar.html。在該文件中,JavaScript函數(shù)createXMLHttpRequest()主要用來(lái)創(chuàng)建XMLHttpRequest對(duì)象,go()函數(shù)完成想服務(wù)器端發(fā)送異步請(qǐng)求,該函數(shù)在網(wǎng)頁(yè)加載時(shí)被調(diào)用,其主要作用就是通知服務(wù)器,并在客戶端開(kāi)始運(yùn)行進(jìn)度條。GoCallback()函數(shù)主要用于處理服務(wù)端的響應(yīng),并每隔2秒調(diào)用pollServer()函數(shù)也是用于向服務(wù)端發(fā)送異步請(qǐng)求,主要請(qǐng)求服務(wù)器端響應(yīng)的百分?jǐn)?shù)字。PollCallback()函數(shù)主要用于處理服務(wù)器端響應(yīng),即依據(jù)服務(wù)器端的返回的數(shù)字,指定進(jìn)度條的顯示狀態(tài)。這里需要注意的是,goCallback()函數(shù)只執(zhí)行一次,而PollCallback()函數(shù)可以執(zhí)行多次,其余的三個(gè)函數(shù)都是實(shí)現(xiàn)進(jìn)度條的輔助函數(shù)。
 
3,運(yùn)行
將上述兩個(gè)Jsp文件復(fù)制到JSP目錄下。運(yùn)行效果圖如下:

201656165706542.jpg (518×153)

相關(guān)文章

  • javascript實(shí)現(xiàn)網(wǎng)站加入收藏功能

    javascript實(shí)現(xiàn)網(wǎng)站加入收藏功能

    這篇文章主要介紹了javascript實(shí)現(xiàn)網(wǎng)站加入收藏功能的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • 手把手教你 CKEDITOR 4 擴(kuò)展插件制作

    手把手教你 CKEDITOR 4 擴(kuò)展插件制作

    這篇文章主要介紹了手把手教你 CKEDITOR 4 擴(kuò)展插件制作,結(jié)合具體實(shí)例形式詳細(xì)分析了CKEditor4插件制作的步驟與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-06-06
  • 微信小程序功能之全屏滾動(dòng)效果的實(shí)現(xiàn)代碼

    微信小程序功能之全屏滾動(dòng)效果的實(shí)現(xiàn)代碼

    最近小編做項(xiàng)目遇到這樣的需求,要求實(shí)現(xiàn)一個(gè)全屏滾動(dòng)的效果,在網(wǎng)上找了實(shí)例代碼,但是不是很完美,小編又結(jié)合自己的知識(shí)給大家補(bǔ)充下,對(duì)微信小程序全屏滾動(dòng)效果的實(shí)例代碼感興趣的朋友參考下本文吧
    2018-11-11
  • JS+CSS實(shí)現(xiàn)的藍(lán)色table選項(xiàng)卡效果

    JS+CSS實(shí)現(xiàn)的藍(lán)色table選項(xiàng)卡效果

    這篇文章主要介紹了JS+CSS實(shí)現(xiàn)的藍(lán)色table選項(xiàng)卡效果,通過(guò)鼠標(biāo)事件調(diào)用自定義函數(shù)實(shí)現(xiàn)頁(yè)面元素樣式的遍歷與動(dòng)態(tài)切換效果,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • 完美實(shí)現(xiàn)仿QQ空間評(píng)論回復(fù)特效

    完美實(shí)現(xiàn)仿QQ空間評(píng)論回復(fù)特效

    這篇文章主要介紹了完美實(shí)現(xiàn)仿QQ空間評(píng)論回復(fù)特效,非常的實(shí)用,附上實(shí)例代碼給大家,有需要的小伙伴參考下吧。
    2015-05-05
  • JS定義類的六種方式詳解

    JS定義類的六種方式詳解

    下面小編就為大家?guī)?lái)一篇JS定義類的六種方式詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧,祝大家游戲愉快哦
    2016-05-05
  • 在JavaScript中驗(yàn)證URL的新方法(2023版)

    在JavaScript中驗(yàn)證URL的新方法(2023版)

    在JavaScript領(lǐng)域,URL 驗(yàn)證方面有了新消息!多年來(lái),人們一直在討論JavaScript沒(méi)有一種簡(jiǎn)便的方法來(lái)驗(yàn)證 URL,現(xiàn)在有了一種新方法URL.canParse(),需要的朋友可以參考下
    2023-09-09
  • 小程序?qū)崿F(xiàn)跑馬燈效果

    小程序?qū)崿F(xiàn)跑馬燈效果

    這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)跑馬燈效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Promise面試題詳解之控制并發(fā)

    Promise面試題詳解之控制并發(fā)

    promise面試中經(jīng)常會(huì)遇到的一個(gè)問(wèn)題就是關(guān)于控制并發(fā)的,所以下面這篇文章主要給大家介紹了關(guān)于Promise面試題之控制并發(fā)的相關(guān)資料,需要的朋友可以參考下
    2021-05-05
  • Extjs 點(diǎn)擊復(fù)選框在表格中增加相關(guān)信息行

    Extjs 點(diǎn)擊復(fù)選框在表格中增加相關(guān)信息行

    這篇文章主要介紹了Extjs 點(diǎn)擊復(fù)選框在表格中增加相關(guān)信息行 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07

最新評(píng)論