[HTML] IE9/IE10使用隐藏iframe异步上传文件问
2016-03-04 本文已影响1803人
何幻
原理:
(1)表单上传原理
<form method="post" action="/Test/Upload" enctype="multipart/form-data">
<input type="file" name="file" />
<input type="submit" />
</form>
为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>alert();</script>'); //响应一段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按钮。