Ajax上传实现根据服务器端返回数据进行js处理的方法
本文实例讲述了Ajax上传实现根据服务器端返回数据进行js处理的方法。分享给大家供大家参考。具体如下:
Ajax上传说白了还是使用form表单提交,在当前页面加一个iframe,将提交的内容跳转到iframe中,造成一种页面无刷新的错觉。
以前也做过上传,基本是是使用commons-fileupload组件,基本的步骤是使用servlet处理完上传之后,使用PrintWrite的对象实例输出显示内容,可以是直接输出内容,也可以是输出script进行操作如
response.getWriter().write("<scripttype=\"text/javascript\">parent.item_update.uploadUponSize();</script>");
或
response.getWriter().write("上传成功!");
这种做法是把对页面端的操作都封装到servlet中,现在一个需求是你接触不到服务器端servlet,而上传成功之后服务器只会返回一个标志符,然后在页面进行操作。
可以根据form表单提交到这个iframe时会触发一个load事件,所以对于这个需求的思路是:
1、在form表单提交时,给iframe注册load事件。
2、然后使用js对返回的标志位进行判断操作。
3、移除绑定事件,避免多次绑定事件。
下面贴一个例子。
对于服务器端简单一点,只会返回一个标志位。
packagecom.justsy.servlet; importjava.io.IOException; importjava.io.PrintWriter; importjavax.servlet.ServletException; importjavax.servlet.http.HttpServlet; importjavax.servlet.http.HttpServletRequest; importjavax.servlet.http.HttpServletResponse; publicclassUploadServletextendsHttpServlet{ privatestaticfinallongserialVersionUID=1L; protectedvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{ this.doPost(request,response); } protectedvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{ PrintWriterwriter=response.getWriter(); response.setContentType("text/html"); writer.print("<root>ok</root>"); } }
js文件
functionsubmitForm(){ $("#hidden_iframe").load(function(){ varcontent=document.getElementById("hidden_iframe").contentWindow.document.body.innerHTML; content=createXml(content); varroot=$(content).find("root").eq(0); alert(root.text()); $("#hidden_iframe").unbind("load"); }); document.getElementById("form2").submit(); } functioncreateXml(str){ if(document.all){ varxmlDom=newActiveXObject("Microsoft.XMLDOM"); xmlDom.loadXML(str); returnxmlDom; } else{ returnnewDOMParser().parseFromString(str,"text/xml"); } }
html文件
<formaction="uploadServlet.do"id="form2"enctype="multipart/form-data"method="post"target="hidden_iframe"> <inputtype="hidden"name="method"value="uploadExcel"/><inputtype="button"value="Submit"onclick="submitForm()"/> </form> <iframename="hidden_iframe"id="hidden_iframe"width="300"height="200"> </iframe>
这样就可以根据页面返回的内容对页面进行操作了。
希望本文所述对大家的Ajax程序设计有所帮助。