婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 讓ajax更加友好的實(shí)現(xiàn)方法(實(shí)時(shí)顯示后臺處理進(jìn)度。)

讓ajax更加友好的實(shí)現(xiàn)方法(實(shí)時(shí)顯示后臺處理進(jìn)度。)

熱門標(biāo)簽:辦理一個400電話多少錢 廣西ai語音電銷機(jī)器人哪家好 察縣地圖標(biāo)注 如何用地圖標(biāo)注各分公司 電銷機(jī)器人適用范圍 蓄意標(biāo)記地圖標(biāo)注 莆田防封電銷卡價(jià)格 信貸電銷機(jī)器人有用嗎 接聽電話機(jī)器人哪有
ajax應(yīng)用越來越多,大部分ajax處理都是在前臺顯示1個"loading...",然后把數(shù)據(jù)提交給服務(wù)器進(jìn)行處理,處理完畢后顯示"處理完畢"。我們能否讓ajax更加友好點(diǎn),實(shí)時(shí)顯示服務(wù)器處理的進(jìn)度了?這在一些長時(shí)間的請求中尤其重要,比如上傳文件、發(fā)送郵件、批量處理數(shù)據(jù)。答案當(dāng)然是可以的,不然就不會寫這個了,對吧,^_^。

存在的問題:
要解決實(shí)現(xiàn)上面的功能,需要解決下面幾個問題:

1. 服務(wù)器如何在處理一部分?jǐn)?shù)據(jù)后傳遞部分response到瀏覽器。
2、瀏覽器如何能處理服務(wù)器傳遞過來部分?jǐn)?shù)據(jù),并保持http連接直到處理完全完畢。

要解決第1個問題,使用flush讓response分塊進(jìn)行呈現(xiàn)就可以了,具體請參考我另一遍隨筆"flush讓頁面分塊,逐步呈現(xiàn)";
第2個問題,則需要用到XMLHttpRequest的readyState狀態(tài),w3c對 readyState 定義如下幾個值:
UNSENT = 0; // 沒有發(fā)送請求
OPENED = 1; // 已經(jīng)打開http連接
HEADERS_RECEIVED = 2; // 接收到response header
LOADING = 3; // 真正接收response body
DONE = 4; // 請求接收完畢
相信狀態(tài)4大家是天天在用,而我們這里需要用到就是狀態(tài)3。
實(shí)例:
廢話少說,代碼實(shí)例比什么文字解釋都管用。我們這里假設(shè)服務(wù)器的1個處理需要6秒種,每秒種處理1條記錄,總共處理6條記錄,我們需要服務(wù)器每處理完1條數(shù)據(jù),客戶端則顯示處理進(jìn)度(包括文字和進(jìn)度條)。
服務(wù)器端代碼(下面JSP代碼):
復(fù)制代碼 代碼如下:

%
// 下面設(shè)置Content-Type:application/x-javascript 是為了適應(yīng)Webkit的瀏覽器(chrome,safari)
response.setHeader("Content-Type","application/x-javascript");
int count = 6; // 處理6條數(shù)據(jù)
for(int i=0;icount;i++){
// 處理完畢一條,輸出結(jié)果到客戶端
out.println(i+1);
out.flush();
// 這里假設(shè)每條數(shù)據(jù)處理時(shí)間為1秒
Thread.currentThread().sleep(1000);
}
%>

html代碼:
復(fù)制代碼 代碼如下:

!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
html xmlns="http://www.w3.org/1999/xhtml">
head>
style>
#divProgress{width:300px;height:24px;position:relative;}
#divProgress div{position:absolute;left:0;top:0;height:24px;}
#progressBg{background-color:#B9F8F9;z-index:10;}
#progressText{z-index:15;text-align:center;width:100%;}
/style>
/head>
body>
div id="divProgress">
div id="progressBg">/div>
div id="progressText">/div>
/div>
br />
button onclick="send()">提交數(shù)據(jù)/button>
script>
var t = document.getElementById("progressText");
var bg = document.getElementById("progressBg");
function send(){
t.innerHTML = "loading...";
bg.style.width = "0px";
var xhr = new window.XMLHttpRequest();
if(!window.XMLHttpRequest){
try {
xhr = new window.ActiveXObject("Microsoft.XMLHTTP");
} catch(e) {}
}
xhr.open("post","http://localhost:801/ChunkTest/chunk.jsp?count=6");
var oldSize=0;
xhr.onreadystatechange = function(){
if(xhr.readyState > 2){
var tmpText = xhr.responseText.substring(oldSize);
oldSize = xhr.responseText.length;
if(tmpText.length > 0 ){
// 設(shè)置文本
t.innerHTML = tmpText + "/6";
// 設(shè)置進(jìn)度條
var width = parseInt(tmpText)/6*300;
bg.style.width = width+"px";
}
}
if(xhr.readyState == 4){
// 請求執(zhí)行完畢
t.innerHTML = "執(zhí)行完畢";
bg.style.width = "300px";
}
}
xhr.send(null);
}
/script>
/body>
/html>

運(yùn)行效果圖: 



缺點(diǎn):

看到這里或許你已經(jīng)蠢蠢欲動,想自己動手試試了。但是注意上面的方法雖好,但也有個缺點(diǎn),就是瀏覽器的支持問題。目前IE所有版本的瀏覽器都不支持 xhr.readyState == 3狀態(tài),IE瀏覽器不支持在response響應(yīng)完畢前讀取responseText屬性。 具體可查看MSDN : XMLHttpRequest Object

基于Webkit的瀏覽器支持的不是很好,需要設(shè)置Content-Type:application/x-javascript才行(經(jīng)測試發(fā)現(xiàn)Content-Type:text/html在有些情況下正常,有些情況下又不正常,而用application/x-javascript都正常)。

看到了缺點(diǎn)后是否又打擊了你的積極性了,其實(shí)針對IE,我們不需要做太多處理,IE不支持,就不會顯示進(jìn)度,就變成跟傳統(tǒng)的ajax請求一樣,一直顯示1個loading直到請求完畢。我們只需要加1個簡單的判斷,判斷如果是ie則不執(zhí)行xhr.readyState > 2中的代碼,如果不加判斷,IE下會報(bào)JS錯誤.

DEMO:

demo服務(wù)器不太好,而且在國外,隨時(shí)可能會點(diǎn)擊不了,而且有時(shí)候運(yùn)行效果不是很好,大家知曉下,最好是把代碼copy到本地進(jìn)行測試.
請使用firefox或chrome查看demo,ie查看的效果跟一般的ajax沒什么不一樣.
http://213.186.44.204:8080/ChunkTest/index.html  
轉(zhuǎn)載請注明出處:http://www.cnblogs.com/BearsTaR/。 禁止商用!
您可能感興趣的文章:
  • AJAX和JSP實(shí)現(xiàn)的基于WEB的文件上傳的進(jìn)度控制代碼
  • AJAX 進(jìn)度條實(shí)現(xiàn)代碼
  • ajax+php打造進(jìn)度條 readyState各狀態(tài)
  • ajax+php打造進(jìn)度條代碼[readyState各狀態(tài)說明]
  • ajax提交加載進(jìn)度條示例代碼
  • 一個簡單的ajax上傳進(jìn)度顯示示例
  • php+ajax實(shí)現(xiàn)帶進(jìn)度條的大數(shù)據(jù)排隊(duì)導(dǎo)出思路以及源碼
  • jquery+php+ajax顯示上傳進(jìn)度的多圖片上傳并生成縮略圖代碼
  • jsp+ajax發(fā)送GET請求的方法
  • jquery+ajax實(shí)現(xiàn)跨域請求的方法
  • asp.net+ajax的Post請求實(shí)例
  • 服務(wù)端配置實(shí)現(xiàn)AJAX跨域請求
  • 解決ajax跨域請求數(shù)據(jù)cookie丟失問題
  • django通過ajax發(fā)起請求返回JSON格式數(shù)據(jù)的方法
  • Ajax在請求過程中顯示進(jìn)度的簡單實(shí)現(xiàn)

標(biāo)簽:阿拉善盟 儋州 鷹潭 益陽 延邊 張掖 銅陵

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《讓ajax更加友好的實(shí)現(xiàn)方法(實(shí)時(shí)顯示后臺處理進(jìn)度。)》,本文關(guān)鍵詞  讓,ajax,更加,友,好的,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《讓ajax更加友好的實(shí)現(xiàn)方法(實(shí)時(shí)顯示后臺處理進(jìn)度。)》相關(guān)的同類信息!
  • 本頁收集關(guān)于讓ajax更加友好的實(shí)現(xiàn)方法(實(shí)時(shí)顯示后臺處理進(jìn)度。)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人午夜电影久久影院| 久久久影院官网| 国产精品入口麻豆原神| 国产一区二区三区精品欧美日韩一区二区三区 | 成人的网站免费观看| 久久久另类综合| 粉嫩aⅴ一区二区三区四区五区| 欧美国产综合色视频| 不卡av在线免费观看| 亚洲精品va在线观看| 欧美日韩国产三级| 麻豆精品一区二区av白丝在线| 精品国产百合女同互慰| 国产精品一二三| 亚洲欧洲综合另类| 51精品视频一区二区三区| 精品一区二区综合| 亚洲人亚洲人成电影网站色| 欧美日韩国产美| 国产一区二区福利| 亚洲精品videosex极品| 日本伦理一区二区| 秋霞av亚洲一区二区三| 久久久一区二区| 91视频在线观看免费| 亚洲 欧美综合在线网络| 精品成人私密视频| 99久久综合99久久综合网站| 亚洲国产综合人成综合网站| 精品成人免费观看| 色偷偷一区二区三区| 免费在线观看一区| 国产精品久久久久久久蜜臀 | 色综合久久66| 久久99精品久久久久久国产越南 | 在线视频一区二区三| 久久精品国产亚洲aⅴ| 中文字幕永久在线不卡| 欧美一二三区精品| 一本色道a无线码一区v| 黄一区二区三区| 亚洲一区在线视频| 国产精品女主播在线观看| 欧美一级一级性生活免费录像| 不卡的av在线播放| 国产毛片精品视频| 日韩va亚洲va欧美va久久| 国产精品视频线看| 精品日韩欧美在线| 在线成人免费观看| 欧美影院一区二区三区| gogo大胆日本视频一区| 激情综合亚洲精品| 日日摸夜夜添夜夜添精品视频| 中文字幕一区不卡| 国产亚洲短视频| 日韩精品中午字幕| 在线成人免费视频| 91精品国产欧美一区二区18| 色狠狠色噜噜噜综合网| av成人免费在线观看| 国产精品18久久久久久久久 | 日韩精品高清不卡| 亚洲一区自拍偷拍| 亚洲老司机在线| 国产精品国产三级国产a| 久久久亚洲精华液精华液精华液| 欧美一区二区免费视频| 欧美日韩一区二区在线观看视频 | 日韩一级视频免费观看在线| 欧美日韩成人综合| 欧美日韩国产一二三| 日本韩国欧美在线| 色哟哟国产精品| 91老师片黄在线观看| 99久久综合99久久综合网站| 91美女片黄在线观看| 91蜜桃在线观看| 欧美优质美女网站| 精品视频一区三区九区| 欧美精品1区2区3区| 欧美精品一二三区| 这里只有精品视频在线观看| 欧美美女视频在线观看| 欧美一级艳片视频免费观看| 欧美va亚洲va在线观看蝴蝶网| 精品毛片乱码1区2区3区| 欧美大片国产精品| 国产视频不卡一区| 亚洲男人都懂的| 午夜a成v人精品| 免费一区二区视频| 国产成人精品午夜视频免费| 成人动漫中文字幕| 在线观看中文字幕不卡| 555www色欧美视频| 国产日韩欧美亚洲| 亚洲欧美日韩精品久久久久| 亚洲超碰精品一区二区| 美女在线一区二区| 岛国一区二区三区| 欧美日韩黄色一区二区| 精品久久国产老人久久综合| 国产精品久久毛片a| 亚洲亚洲人成综合网络| 极品销魂美女一区二区三区| 不卡一区中文字幕| 欧美日韩精品欧美日韩精品一| 欧美大片免费久久精品三p| 综合久久国产九一剧情麻豆| 天天综合色天天| 国产电影一区在线| 欧美日韩成人高清| 国产亚洲成av人在线观看导航| 亚洲与欧洲av电影| 高潮精品一区videoshd| 欧美绝品在线观看成人午夜影视| 久久久国际精品| 午夜视频在线观看一区| 国产91对白在线观看九色| 欧美日韩一区 二区 三区 久久精品| 日韩精品中文字幕在线一区| 玉足女爽爽91| 国产福利一区二区| 欧美精品丝袜久久久中文字幕| 中文字幕乱码一区二区免费| 日本不卡一二三| 色欧美88888久久久久久影院| 久久综合国产精品| 亚洲v中文字幕| 99精品久久只有精品| 精品国产成人在线影院| 日韩综合小视频| 91视频在线观看免费| 国产视频在线观看一区二区三区| 丝袜美腿成人在线| 色综合色综合色综合色综合色综合| 精品国精品国产尤物美女| 亚洲国产一区二区a毛片| 成av人片一区二区| 亚洲国产精品av| 美国欧美日韩国产在线播放| 欧美日韩一区小说| 亚洲最色的网站| 99国产精品久久久久久久久久久 | 亚洲成人免费看| 成人激情校园春色| 久久日韩精品一区二区五区| 奇米精品一区二区三区四区| 欧美调教femdomvk| 一区二区三区免费网站| 99re8在线精品视频免费播放| 久久久久九九视频| 精品一区二区免费在线观看| 欧美一区二区成人| 免费在线一区观看| 日韩女优毛片在线| 久久精品国产一区二区| 日韩三级av在线播放| 美腿丝袜一区二区三区| 日韩精品一区二区三区在线播放 | 欧美午夜不卡视频| 亚洲一区二区四区蜜桃| 色一情一乱一乱一91av| 依依成人综合视频| 在线亚洲免费视频| 亚洲成人资源网| 欧美一区二区三区不卡| 久久精品国产在热久久| 久久精品人人做人人综合| 成人午夜在线视频| 1000精品久久久久久久久| 色国产综合视频| 天堂va蜜桃一区二区三区| 欧美一区二区视频在线观看2020 | 青青草伊人久久| 日韩午夜激情av| 国产一区在线观看视频| 国产午夜亚洲精品理论片色戒| 国产久卡久卡久卡久卡视频精品| 国产三级精品三级| 99在线精品视频| 一区二区高清视频在线观看| 欧美日韩亚洲不卡| 激情伊人五月天久久综合| 国产午夜精品福利| 91在线国内视频| 日韩和欧美一区二区| 26uuuu精品一区二区| av亚洲精华国产精华精| 亚洲成a人v欧美综合天堂| 精品国产电影一区二区| 91在线视频观看| 久久精品国产精品亚洲精品| 国产区在线观看成人精品| 色av综合在线| 国内欧美视频一区二区| 亚洲免费av在线| 欧美电影免费观看高清完整版在线| 成人精品国产福利|