咖啡加糖609的gravatar头像
咖啡加糖609 2015-02-06 17:08:38

为什么jquery在IE浏览器无法上传图片,报SCRIPT5: 拒绝访问的错误,谷歌和360都正常?

贴出主要代码:

 $.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下  这个表单的submit不提交,alert也打不出来报错SCRIPT5: 拒绝访问。

所有回答列表(2)
xiaoduzi的gravatar头像
xiaoduzi  LV5 2015年2月14日

你应该是用JS间接调用文件的单击事件弹出选择框吧,IE是不允许的

sunjiyun26的gravatar头像
sunjiyun26  LV9 2018年12月14日

alert应该在前边,submit之前应该就出错了

顶部 客服 微信二维码 底部
>扫描二维码关注最代码为好友扫描二维码关注最代码为好友