讓ajax更加友好的實現方法(實時顯示后臺處理進度。)
2024-09-01 08:29:16
供稿:網友
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 id="divProgress">
<div id="progressBg"></div>
<div id="progressText"></div>
</div>
<br />
<button onclick="send()">提交數據</button>
<script>
var t = document.getElementById("progressText");
var bg = document.getElementById("progressBg");
function send(){
t.innerHTML = "loading...";
bg.style.width = "0px";