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" οnclick="submitForm()"/>
        </form>
        <iframe name="hidden_iframe" id="hidden_iframe" width="300" height="200">
        </iframe>

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




评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值