首頁 > web前端 > js教程 > 主體

Ajax上傳實作根據伺服器端傳回資料進行js處理的方法

亚连
發布: 2018-05-25 10:31:28
原創
1491 人瀏覽過

這篇文章主要介紹了Ajax上傳實現根據伺服器端返回資料進行js處理的方法,實例分析了Ajax請求及java處理並返回伺服器端資料請求的相關技巧

本文實例講述了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>
登入後複製
#########上面是我整理給大家的,希望今後會對大家有幫助。 ######相關文章:#########django使用ajax post資料出現403錯誤如何解決###############淺析IE針對Ajax請求結果的快取問題###############各種AJAX方法的使用比較詳解####################### ###

以上是Ajax上傳實作根據伺服器端傳回資料進行js處理的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!