亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

讓ajax更加友好的實現方法(實時顯示后臺處理進度。)

2024-09-01 08:31:27
字體:
來源:轉載
供稿:網友
我們能否讓ajax更加友好點,實時顯示服務器處理的進度了?這在一些長時間的請求中尤其重要,比如上傳文件、發送郵件、批量處理數據。

ajax應用越來越多,大部分ajax處理都是在前臺顯示1個"loading...",然后把數據提交給服務器進行處理,處理完畢后顯示"處理完畢"。我們能否讓ajax更加友好點,實時顯示服務器處理的進度了?這在一些長時間的請求中尤其重要,比如上傳文件、發送郵件、批量處理數據。答案當然是可以的,不然就不會寫這個了,對吧,^_^。

存在的問題:
要解決實現上面的功能,需要解決下面幾個問題:

1. 服務器如何在處理一部分數據后傳遞部分response到瀏覽器。
2、瀏覽器如何能處理服務器傳遞過來部分數據,并保持http連接直到處理完全完畢。

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

復制代碼 代碼如下:


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


html代碼:

復制代碼 代碼如下:


<!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>
<div></div>
<div></div>
</div>
<br />
<button>提交數據</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 ){
// 設置文本
t.innerHTML = tmpText + "/6";
// 設置進度條
var width = parseInt(tmpText)/6*300;
bg.style.width = width+"px";
}
}
if(xhr.readyState == 4){
// 請求執行完畢
t.innerHTML = "執行完畢";
bg.style.width = "300px";
}
}
xhr.send(null);
}
</script>
</body>
</html>


運行效果圖:


缺點:

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

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

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

DEMO:

demo服務器不太好,而且在國外,隨時可能會點擊不了,而且有時候運行效果不是很好,大家知曉下,最好是把代碼copy到本地進行測試.
請使用firefox或chrome查看demo,ie查看的效果跟一般的ajax沒什么不一樣.
:8080/ChunkTest/index.html
轉載請注明出處:。 禁止商用!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美高清在线视频| 一区二区三区黄色| 亚洲aⅴ男人的天堂在线观看| 久久99久久久久久久噜噜| 日韩电视剧在线观看免费网站| 色综合久综合久久综合久鬼88| 国产精品视频99| 精品一区二区三区四区| www国产精品视频| 欧美电影免费观看高清| 国产成一区二区| 午夜精品久久久久久久99黑人| 日韩精品中文字幕在线观看| 91亚洲一区精品| 日韩电影免费观看在线观看| 色无极影院亚洲| 国产精品v日韩精品| 国产精品久久久久秋霞鲁丝| 1769国内精品视频在线播放| 欧美老女人xx| 久99久在线视频| 日本高清不卡在线| 欧美日韩中文字幕在线| 成人午夜激情网| 欧美日本精品在线| 欧美激情在线一区| 亚洲乱亚洲乱妇无码| 欧美乱妇40p| 亚洲日本中文字幕| 亚洲精品日韩欧美| 久久亚洲综合国产精品99麻豆精品福利| 91视频国产高清| 国产精品久久久久久久久久新婚| 日韩精品视频观看| 欧美日韩一区二区在线| 亚洲精品自拍第一页| 日韩亚洲第一页| 久久福利网址导航| 久久久99免费视频| 欧美wwwwww| 亚洲网站在线看| 欧美日韩中文字幕在线视频| 97精品国产97久久久久久免费| 国产成人一区二| 91精品国产91久久久久福利| 国产精品嫩草影院久久久| 国产精品欧美日韩一区二区| 国内偷自视频区视频综合| 亚洲福利在线观看| 亚洲激情视频在线观看| 国产国语videosex另类| 中文字幕久热精品在线视频| 日韩精品中文字幕有码专区| 亚洲人成毛片在线播放| 91精品综合久久久久久五月天| 日本不卡视频在线播放| 日韩av在线网页| 亚洲国产精品大全| 日韩在线欧美在线国产在线| 国产91精品在线播放| 亚洲男女性事视频| 色综合久久天天综线观看| 国产xxx69麻豆国语对白| 欧美猛男性生活免费| 懂色av中文一区二区三区天美| 欧美激情2020午夜免费观看| 亚洲电影天堂av| 美女999久久久精品视频| 中文字幕欧美日韩va免费视频| 欧美老妇交乱视频| 亚洲一区中文字幕在线观看| 欧美午夜xxx| 国产精品video| 久久久中文字幕| 亚洲男人av在线| 国产成人小视频在线观看| 最好看的2019年中文视频| 国产精品毛片a∨一区二区三区|国| 欧美性猛交xxxx偷拍洗澡| 国产亚洲精品久久久久久777| 亚洲激情久久久| 中文字幕视频一区二区在线有码| 4438全国亚洲精品在线观看视频| 久久99精品视频一区97| 日韩综合中文字幕| 最近2019年手机中文字幕| 97碰碰碰免费色视频| 国产91精品久久久久| 北条麻妃99精品青青久久| 欧美大片免费观看| 国产福利精品在线| 久久久久国色av免费观看性色| 欧美性精品220| 欧美大片网站在线观看| 欧美性猛交丰臀xxxxx网站| 亚洲精品91美女久久久久久久| 国产亚洲精品激情久久| 在线观看国产精品淫| 欧洲精品久久久| 亚洲欧美日韩国产中文专区| 日韩欧美在线字幕| 亚洲欧洲日产国码av系列天堂| 91精品中文在线| 国产精品免费一区豆花| 日韩电影免费观看在线观看| 97视频免费在线观看| 国产亚洲精品美女久久久| 色偷偷噜噜噜亚洲男人的天堂| 亚洲欧美日韩视频一区| 亚洲人在线观看| 欧洲永久精品大片ww免费漫画| 欧美第一黄网免费网站| 国产精品永久免费观看| 国产精品美女久久久免费| 操日韩av在线电影| 亚洲欧美视频在线| 色久欧美在线视频观看| 国产成人精品a视频一区www| 国内精品视频久久| 丝袜美腿亚洲一区二区| 欧美专区在线视频| 欧美视频第一页| 欧美特黄级在线| 亚洲欧美综合另类中字| 国产在线视频91| 中文字幕日韩av| 欧美成人一区二区三区电影| 国产精品欧美久久久| 国内精品伊人久久| 国产精品27p| 在线国产精品视频| 在线播放日韩av| 韩国国内大量揄拍精品视频| 久久久久国产精品www| 欧美成人免费在线视频| 成人美女免费网站视频| 久久久视频在线| 高清欧美电影在线| 日韩成人免费视频| 26uuu久久噜噜噜噜| 高清日韩电视剧大全免费播放在线观看| 国产91精品网站| 日韩欧美中文在线| 欧美高清自拍一区| 欧美成人合集magnet| 精品视频一区在线视频| 欧美日韩国产精品一区二区三区四区| 不卡av在线网站| 亚洲精品ady| 国产成人亚洲综合91| 在线观看久久av| 日韩av毛片网| 性欧美视频videos6一9| 亚洲aⅴ日韩av电影在线观看| 久久久999国产精品| 欧美大码xxxx| 欧美性受xxx| 亚洲欧美综合图区| 亚洲美女视频网| 国产91av在线| 81精品国产乱码久久久久久| 日韩欧美999| 色偷偷av一区二区三区乱| 精品久久久久久久久久久久久久|