IE9/IE10使用隐藏iframe异步上传文件问题

时间: 2017-11-20阅读: 1597标签: iframe

原理:

(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按钮移动到该按钮上面,这样实际点击的是移动到此处的file按钮。

$('#button1').mousemove(function(e){
var left=e.pageX, //鼠标位置
top=e.pageY; //鼠标位置
$(':file').css({
left:left,
top:top
});
});



站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/136

关闭

iframe onload事件被block的坑

最近接手了一个古旧的项目,跟客户端、服务器端一起调一个支付相关的app内嵌H5页面,这个页面有两部分组成,主页面A加上一个最终支付页面B,B页面是通过iframe嵌入到A页面中的,A、B两个页面之间的交互采用postMessage+hashChange

内嵌iframe页面在IOS下会受内部元素影响自动撑开的问题

具体表现为iframe页面内的子元素一旦超出原先的边界,只要能影响到html元素的宽高,就会自动撑开iframe,即使html元素设置了overflow:hidden也没用。

iframe中跨域页面访问parent的方法

在AAA.com域名下的index.htm页面中内嵌了BBB.com域名下的一个页面index.htm,正常情况下iframe内部的index.htm页面是无法访问父页面index.htm中的任何dom对象或者js函数的,因为跨域,但我们经常又需要做一些参数回传的事情怎么办呢?以上的这种实现方式就很好的解决了这个问题

iframe高度自适应

我们知道,iframe最大的问题,就是高度的问题,如果你内容的高度是变化,要么你就给你的容器写个固定的高度,如果内容是未知的,显然这个方法并不能达到我们的想要的效果,要么就是通过js来解决这个问题。

iframe的父子页面进行简单的相互传值

当一个页面使用了iframe作为嵌套时,如何想要将父页面的数据传给iframe子页面,那iframe所指向的呢个子页面是怎么获取呢,又或者子页面的数据要给父页面使用,那么父页面又如何获取子页面的数据呢?

载入的iframe页面会挡住父级页面一切冒泡事件,怎么破?

最近遇到个坑,页面引入了一个iframe,结果页面上所有的点击事件都失效了。解决办法是手动绑定iframe里面事件,在事件里面触发当前窗口事件

iframe在iphone手机上的问题

通过document.addEventListener(\\\"scroll\\\",function(){})对页面滚动监听事件进行监听,但ios下$(document).scrollTop()值始终为0,对页面监听无效。

iframe标签刷新页面停留在当前页

整体思路:在iframe所在当前页面地址url后拼接 #+targetUrl,iframe标签内a标签跳转,父页面添加如下方法,iframe标签内调用父页面js方法用 window.parent.jsfun() 调用。

JS操作iframe元素

页面中有个iframe元素,iframe元素的src是iframe1.html,怎么在demo1.html页面中操作iframe1.html页面,js先找到iframe元素(比如命名为:oIframe),那么oIframe.contentWindow就是iframe1.html这个页面的window

如何优雅的使用iframe?

iframe在web应用刀耕火种的开发年代是非常常见的,现在基于Node构建的前端应用嵌入iframe的场景越来越少了,但是在大型的web应用中也会经常遇见利用iframe嵌入多个前端应用于一套前端系统中,方便用户在一个系统中去进行业务操作

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!