Ajax上傳實現(xiàn)根據(jù)服務(wù)器端返回數(shù)據(jù)進行js處理的方法
本文實例講述了Ajax上傳實現(xiàn)根據(jù)服務(wù)器端返回數(shù)據(jù)進行js處理的方法。分享給大家供大家參考。具體如下:
Ajax上傳說白了還是使用form表單提交,在當(dāng)前頁面加一個iframe,將提交的內(nèi)容跳轉(zhuǎn)到iframe中,造成一種頁面無刷新的錯覺。
以前也做過上傳,基本是是使用commons-fileupload組件,基本的步驟是使用servlet處理完上傳之后,使用PrintWrite的對象實例輸出顯示內(nèi)容,可以是直接輸出內(nèi)容,也可以是輸出script進行操作如
或
這種做法是把對頁面端的操作都封裝到servlet中,現(xiàn)在一個需求是你接觸不到服務(wù)器端servlet,而上傳成功之后服務(wù)器只會返回一個標(biāo)志符,然后在頁面進行操作。
可以根據(jù)form表單提交到這個iframe時會觸發(fā)一個load事件,所以對于這個需求的思路是:
1、在form表單提交時,給iframe注冊load事件。
2、然后使用js對返回的標(biāo)志位進行判斷操作。
3、移除綁定事件,避免多次綁定事件。
下面貼一個例子。
對于服務(wù)器端簡單一點,只會返回一個標(biāo)志位。
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>
這樣就可以根據(jù)頁面返回的內(nèi)容對頁面進行操作了。
希望本文所述對大家的Ajax程序設(shè)計有所幫助。
- js實現(xiàn)圖片上傳到服務(wù)器和回顯
- Node.js HTTP服務(wù)器中的文件、圖片上傳的方法
- JSP+Servlet實現(xiàn)文件上傳到服務(wù)器功能
- NodeJs實現(xiàn)簡易WEB上傳下載服務(wù)器
- 詳解Node.js一行命令上傳本地文件到服務(wù)器
- js實現(xiàn)圖片粘貼上傳到服務(wù)器并展示的實例
- 基于HTML5+js+Java實現(xiàn)單文件文件上傳到服務(wù)器功能
- 利用nodejs監(jiān)控文件變化并使用sftp上傳到服務(wù)器
- NodeJS與HTML5相結(jié)合實現(xiàn)拖拽多個文件上傳到服務(wù)器的實現(xiàn)方法
- js實現(xiàn)上傳圖片到服務(wù)器
相關(guān)文章
ajax+asp無限級分類樹型結(jié)構(gòu)的代碼
ajax+asp無限級分類樹型結(jié)構(gòu)的代碼...2007-10-10laravel ajax curd 搜索登錄判斷功能的實現(xiàn)
這篇文章主要介紹了laravel ajax curd 搜索登錄判斷功能的實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04$.ajax傳JSON數(shù)據(jù)到后臺出現(xiàn)報錯問題解決
$.ajax傳JSON數(shù)據(jù)到后臺時總會出現(xiàn)一些錯誤,本文整理了一些注意事項,感興趣的朋友可以參考下2014-01-01Ajax請求二進制流進行處理(ajax異步下載文件)的簡單方法
最近做項目遇到這樣的需求:管理后臺需要隨時下載數(shù)據(jù)報表,數(shù)據(jù)要實時生成后轉(zhuǎn)換為excel下載。怎么解決這個問題呢?下面小編給大家分享Ajax請求二進制流進行處理(ajax異步下載文件)的簡單方法,一起看看吧2017-09-09