• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Ajax上传实现根据服务器端返回数据进行js处理的方法

    本文实例讲述了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>
    
    

    这样就可以根据页面返回的内容对页面进行操作了。

    希望本文所述对大家的Ajax程序设计有所帮助。

    您可能感兴趣的文章:
    • js实现图片上传到服务器和回显
    • Node.js HTTP服务器中的文件、图片上传的方法
    • JSP+Servlet实现文件上传到服务器功能
    • NodeJs实现简易WEB上传下载服务器
    • 详解Node.js一行命令上传本地文件到服务器
    • js实现图片粘贴上传到服务器并展示的实例
    • 基于HTML5+js+Java实现单文件文件上传到服务器功能
    • 利用nodejs监控文件变化并使用sftp上传到服务器
    • NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法
    • js实现上传图片到服务器
    上一篇:ajax遍历xml文档的方法
    下一篇:双层ajax嵌套(可多层)用法实例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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