ajax将响应结果显示到iframe,ajaxsubmit返回值在IE下弹出保存提示问题

使用jquery.form插件的ajaxSubmit上传文件时,在IE、chorme会出现下载文件的提示框,在查看了jquery.form的源码时,发现了下面的代码:if (options.iframe !== false && (options.iframe || shouldUseFrame)) {

if (options.closeKeepAlive) {

$.get(options.closeKeepAlive, function() {

fileUploadIframe(a);

});

}

else {

fileUploadIframe(a);

}

}

else if ((hasFileInputs || multipart) && fileAPI) {

fileUploadXhr(a);

}

else {

$.ajax(options);

}

在ajaxSubmit提交表单的时候,如果表单内有文件上传的话,会判断参数是否配置的iframe为false参数,如果没有,会用创建隐藏iframe方式提交表单,如果设定了iframe为false,则判断浏览器是否支持HTML5的fileAPI,支持就直接使用XHR方式提交,否则就当作普通表单提交。

因为是用隐藏iframe提交的表单,如果服务器返回的是“application/json”类型的数据,IE和Chrome默认是下载文件的,因为内容是返回给了iframe,而不是ajaxSubmit的success方法。在iframe加载了返回结果后,ajaxSubmit的success方法是去读取iframe的内容来转换成json对象使用。

解决办法

在ajaxSubmit提交表单时,返回“text/html”类型的内容,普通的ajax则返回“application/json”的内容。

Map map = new HashMap();

map.put("","");

returnData = JSONObject.fromObject(map);

response.setContentType("text/html");

response.getWriter().println(jsonObject.toString());

返回“text/html”类型的内容可能会出现的问题

如果需要解析file的内容,且file的内容包含“,”、“{”、“}”,可能会破坏json object的结构,导致ajaxSubmit无法以json格式解析返回的data,抛出如下错误:

ajaxsubmit SyntaxError: JSON.parse: expected ',' or '}' after property value

为fix这个问题,可以将$.ajaxsubmit的dataType属性设为text,但如此,需要手动的解析返回的json string,比较困难,建议以简单的form submit()方法,提交form到后台,然后利用model返回data,避免ajaxsubmit SyntaxError,可是无法避免刷新页面,违背了ajax局部刷新的初衷。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值