jquery.upload.js ie下不能上传
做了一个图片上传,谷歌和360上面是可以的,但是ie上面无法上传,
主要代码如下:
upload上传主要代码:
$.upload = function(options) {
var opts = $.extend(jQuery.uploadDefault, options);
if (opts.url == '') {
return;
}
var canSend = opts.onSend();
if (!canSend) {
return;
}
var frameName = 'upload_frame_' + (frameCount++);
var iframe = $('<iframe style="position:absolute;top:-9999px" />').attr('name', frameName);
var form = $('<form method="post" style="display:none;" enctype="multipart/form-data" />').attr('name', 'form_' + frameName);
form.attr("target", frameName).attr('action', opts.url);
// form中增加数据域
var formHtml = '<input type="file" name="' + opts.fileName + '" onchange="onChooseFile(this)">';
for (key in opts.params) {
formHtml += '<input type="hidden" name="' + key + '" value="' + opts.params[key] + '">';
}
form.append(formHtml);
iframe.appendTo("body");
form.appendTo("body");
form.submit(opts.onSubmit);
// iframe 在提交完成之后
iframe.load(function() {
var contents = $(this).contents().get(0);
var data = $(contents).find('body').text();
if ('json' == opts.dataType&&data!='') {
data = window.eval('(' + data + ')');
}
opts.onComplate(data);
setTimeout(function() {
iframe.remove();
form.remove();
}, 5000);
});
// 文件框
var fileInput = $('input[type=file][name=' + opts.fileName + ']', form);
fileInput.click();
};
红色的字体为选择文件事件,具体事件如下,
// 选中文件, 提交表单(开始上传)
var onChooseFile = function(fileInputDOM) {
var form = $(fileInputDOM).parent();
form.submit();
alert("提交了~~~~")
};
ie下 这个alert()始终不能打出来 ,求解了
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
不同浏览器效果不同就要考虑浏览器的兼容性了
使用ajaxfileupload 支持所有浏览器
看过了这个js的源代码,在uploadfile这个方法中提交ajax的时候用到了FormData,而FormData是有兼容性问题的,可以了解以下FormData