ie添加html文件上传,[HTML] IE9/IE10使用隐藏iframe异步上传文件问题

原理:

(1)表单上传原理

为form表单添加属性enctype="multipart/form-data",

选择文件后提交表单即可上传文件。

C#服务器端通过HttpPostedFileBase file来接收文件。

(2)异步上传原理

表单提交是同步的,会阻塞页面,

可以将表单提交到一个iframe中,父页面就不会阻塞了。

需要设置form的target属性等于iframe的name属性。

form[target]=iframe[name]

(3)上传完成后事件

服务器端只是单纯对表单提交的响应,

可以返回一段script脚本作为http响应流,执行javascript。

Response.Write(''); //响应一段script脚本

Response.Flush(); //强制清空缓冲区,写入响应流

对于iframe异步上传情形,Response是iframe的响应,

返回的script脚本中,可以使用parent获取父页面的window对象。

场景:

为了把异步上传封装成插件,需要对选择文件和上传成功事件提供javascript接口,

就不得不用javascript来触发表单中file按钮的点击。

$(':file').click();

这样做,会打开选择文件对话框。

然后,调用$('form').submit();或$(':submit').click();来提交表单。

问题:

在IE9/IE10中,$(':file').click();这样触发的选择文件操作,不能上传文件。

原因:

IE9/IE10限制,file按钮必须由用户点击才可以上传,

虽然$(':file').click();可以选择文件,

但是提交表单会先清空选取的内容,多次点击才会上传选中的文件。

解决方案:

限制file按钮的大小width:0;height:0;,并设置绝对定位position:absolute;

某个按钮点击时,在mousemove事件中,把file按钮移动到该按钮上面,

$('#button1').mousemove(function(e){

var left=e.pageX, //鼠标位置

top=e.pageY; //鼠标位置

$(':file').css({

left:left,

top:top

});

});

这样实际点击的是移动到此处的file按钮。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值