这篇文章主要介绍了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处理的方法的详细内容。
   
 
   