首页 > 开发 > AJAX > 正文

Ajax上传实现根据服务器端返回数据进行js处理的方法

2024-09-01 08:28:29
字体:
来源:转载
供稿:网友

本文实例讲述了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>            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表