我使用Blueimp Jquery File Upload插件异步上传文件。它适用于大多数其他浏览器(有一些小问题) - 在IE上,我看到这个问题,“完成”,“停止”,“始终”,“完成”和其他一些事件回调没有被调用。
在调试时,我在“完成”,“失败”,“始终”中添加了console.logs,并在_onSend函数中添加了一个“完整”方法(在jquery.fileupload.js中) - 但是似乎没有一个在IE中被调用。
_onSend: function (e, data) {
var that = this,
jqXHR,
slot,
pipe,
options = that._getAJAXSettings(data),
send = function (resolve, args) {
that._sending += 1;
jqXHR = jqXHR || (
(resolve !== false &&
that._trigger('send', e, options) !== false &&
(that._chunkedUpload(options) || $.ajax(options))) ||
that._getXHRPromise(false, options.context, args)
).complete(function (result, textStatus, jqXHR) {
console.log("complete");
}).done(function (result, textStatus, jqXHR) {
console.log("done", result);
}).fail(function (jqXHR, textStatus, errorThrown) {
console.log("fail", result);
}).always(function (a1, a2, a3) {
console.log("done", result);
}
});
return jqXHR;
};
[为了便于阅读而修剪了插件代码]
据我所知,在IE 9中,jquery.iframe-transport.js用于文件上传(因为IE中不支持XHR文件上传)。
我不确定如何修复/调试此问题。
谢谢!
答案 0 :(得分:19)
如果在从服务器返回json时将响应的content-type设置为“text / html”或“text / plain”(而不是application / json),则会触发done事件。这仅适用于不支持XHR文件上传的浏览器(例如IE9)以及blueimp插件使用IFrame传输的地方。
插件文档中“内容协商”下的相关信息: https://github.com/blueimp/jQuery-File-Upload/wiki/Setup
答案 1 :(得分:6)
为了记录,我在直接上传到S3时遇到了这个问题,现在他们的CORS功能允许这样做。
解决方案是将success_action_status设置为'200',然后正确触发Done事件。
答案 2 :(得分:1)
如果有人在直接上传到S3时仍遇到此问题,解决方案是添加值为“201”的 success_action_status 字段。确保您将其作为政策数据的一部分包含在内,因为它们必须匹配。
显然,当从IE9 S3接收上传时,将返回一个空字符串。要让它返回文件上传器需要的XML,你必须告诉它返回201的状态。