本文實例講述了Ajax上傳實現根據服務器端返回數據進行js處理的方法。分享給大家供大家參考。具體如下:
Ajax上傳說白了還是使用form表單提交,在當前頁面加一個iframe,將提交的內容跳轉到iframe中,造成一種頁面無刷新的錯覺。
以前也做過上傳,基本是是使用commons-fileupload組件,基本的步驟是使用servlet處理完上傳之后,使用PrintWrite的對象實例輸出顯示內容,可以是直接輸出內容,也可以是輸出script進行操作如
復制代碼 代碼如下:
response.getWriter().write("script type=\"text/javascript\"> parent.item_update.uploadUponSize();/script>");
或
復制代碼 代碼如下:
response.getWriter().write("上傳成功!");
這種做法是把對頁面端的操作都封裝到servlet中,現在一個需求是你接觸不到服務器端servlet,而上傳成功之后服務器只會返回一個標志符,然后在頁面進行操作。
可以根據form表單提交到這個iframe時會觸發一個load事件,所以對于這個需求的思路是:
1、在form表單提交時,給iframe注冊load事件。
2、然后使用js對返回的標志位進行判斷操作。
3、移除綁定事件,避免多次綁定事件。
下面貼一個例子。
對于服務器端簡單一點,只會返回一個標志位。
package com.justsy.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class UploadServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response) ;
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
PrintWriter writer = response.getWriter() ;
response.setContentType("text/html") ;
writer.print("root>ok/root>") ;
}
}
js文件
function submitForm(){
$("#hidden_iframe").load(function(){
var content = document.getElementById("hidden_iframe").contentWindow.document.body.innerHTML;
content = createXml(content);
var root = $(content).find("root").eq(0);
alert(root.text());
$("#hidden_iframe").unbind("load");
});
document.getElementById("form2").submit();
}
function createXml(str){
if (document.all) {
var xmlDom = new ActiveXObject("Microsoft.XMLDOM");
xmlDom.loadXML(str);
return xmlDom;
}
else {
return new DOMParser().parseFromString(str, "text/xml");
}
}
html文件
form action="uploadServlet.do" id="form2" enctype="multipart/form-data" method="post" target="hidden_iframe">
input type="hidden" name="method" value="uploadExcel" />input type="button" value="Submit" onclick="submitForm()"/>
/form>
iframe name="hidden_iframe" id="hidden_iframe" width="300" height="200">
/iframe>
這樣就可以根據頁面返回的內容對頁面進行操作了。
希望本文所述對大家的Ajax程序設計有所幫助。
您可能感興趣的文章:- js實現圖片上傳到服務器和回顯
- Node.js HTTP服務器中的文件、圖片上傳的方法
- JSP+Servlet實現文件上傳到服務器功能
- NodeJs實現簡易WEB上傳下載服務器
- 詳解Node.js一行命令上傳本地文件到服務器
- js實現圖片粘貼上傳到服務器并展示的實例
- 基于HTML5+js+Java實現單文件文件上傳到服務器功能
- 利用nodejs監控文件變化并使用sftp上傳到服務器
- NodeJS與HTML5相結合實現拖拽多個文件上傳到服務器的實現方法
- js實現上傳圖片到服務器