主頁(yè) > 知識(shí)庫(kù) > Ajax上傳實(shí)現(xiàn)根據(jù)服務(wù)器端返回?cái)?shù)據(jù)進(jìn)行js處理的方法

Ajax上傳實(shí)現(xiàn)根據(jù)服務(wù)器端返回?cái)?shù)據(jù)進(jìn)行js處理的方法

熱門標(biāo)簽:上海浦東百度地圖標(biāo)注中心注冊(cè) 外呼系統(tǒng)獲取客戶手機(jī)號(hào) 老虎郵局地圖標(biāo)注點(diǎn) 徐州電銷卡外呼系統(tǒng)供應(yīng)商 科智聯(lián)智能電銷機(jī)器人 襄陽(yáng)外呼系統(tǒng)接口 目標(biāo)三維地圖標(biāo)注 青海醫(yī)療智能外呼系統(tǒng)怎么樣 百靈鳥

本文實(shí)例講述了Ajax上傳實(shí)現(xiàn)根據(jù)服務(wù)器端返回?cái)?shù)據(jù)進(jìn)行js處理的方法。分享給大家供大家參考。具體如下:

Ajax上傳說(shuō)白了還是使用form表單提交,在當(dāng)前頁(yè)面加一個(gè)iframe,將提交的內(nèi)容跳轉(zhuǎn)到iframe中,造成一種頁(yè)面無(wú)刷新的錯(cuò)覺(jué)。

以前也做過(guò)上傳,基本是是使用commons-fileupload組件,基本的步驟是使用servlet處理完上傳之后,使用PrintWrite的對(duì)象實(shí)例輸出顯示內(nèi)容,可以是直接輸出內(nèi)容,也可以是輸出script進(jìn)行操作如

復(fù)制代碼 代碼如下:
response.getWriter().write("script type=\"text/javascript\"> parent.item_update.uploadUponSize();/script>");


復(fù)制代碼 代碼如下:
response.getWriter().write("上傳成功!");

這種做法是把對(duì)頁(yè)面端的操作都封裝到servlet中,現(xiàn)在一個(gè)需求是你接觸不到服務(wù)器端servlet,而上傳成功之后服務(wù)器只會(huì)返回一個(gè)標(biāo)志符,然后在頁(yè)面進(jìn)行操作。
可以根據(jù)form表單提交到這個(gè)iframe時(shí)會(huì)觸發(fā)一個(gè)load事件,所以對(duì)于這個(gè)需求的思路是:

1、在form表單提交時(shí),給iframe注冊(cè)load事件。

2、然后使用js對(duì)返回的標(biāo)志位進(jìn)行判斷操作。

3、移除綁定事件,避免多次綁定事件。

下面貼一個(gè)例子。

對(duì)于服務(wù)器端簡(jiǎn)單一點(diǎn),只會(huì)返回一個(gè)標(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ù)頁(yè)面返回的內(nèi)容對(duì)頁(yè)面進(jìn)行操作了。

希望本文所述對(duì)大家的Ajax程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • js實(shí)現(xiàn)圖片上傳到服務(wù)器和回顯
  • Node.js HTTP服務(wù)器中的文件、圖片上傳的方法
  • JSP+Servlet實(shí)現(xiàn)文件上傳到服務(wù)器功能
  • NodeJs實(shí)現(xiàn)簡(jiǎn)易WEB上傳下載服務(wù)器
  • 詳解Node.js一行命令上傳本地文件到服務(wù)器
  • js實(shí)現(xiàn)圖片粘貼上傳到服務(wù)器并展示的實(shí)例
  • 基于HTML5+js+Java實(shí)現(xiàn)單文件文件上傳到服務(wù)器功能
  • 利用nodejs監(jiān)控文件變化并使用sftp上傳到服務(wù)器
  • NodeJS與HTML5相結(jié)合實(shí)現(xiàn)拖拽多個(gè)文件上傳到服務(wù)器的實(shí)現(xiàn)方法
  • js實(shí)現(xiàn)上傳圖片到服務(wù)器

標(biāo)簽:紅河 商洛 佛山 辛集 股票 揭陽(yáng) 咸寧 荊州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Ajax上傳實(shí)現(xiàn)根據(jù)服務(wù)器端返回?cái)?shù)據(jù)進(jìn)行js處理的方法》,本文關(guān)鍵詞  Ajax,上傳,實(shí)現(xiàn),根據(jù),服務(wù)器,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Ajax上傳實(shí)現(xiàn)根據(jù)服務(wù)器端返回?cái)?shù)據(jù)進(jìn)行js處理的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Ajax上傳實(shí)現(xiàn)根據(jù)服務(wù)器端返回?cái)?shù)據(jù)進(jìn)行js處理的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章