IE input type=file 隐藏时不能上传文件
2014-06-26 00:00
531 查看
摘要: IE浏览器中隐藏的input框(type="file"),是无法上传文件的,可以通过设置他的opacity为0,让它完全透明来实现
又是IE的一个问题,近来是跟IE浏览器磕上了,这个问题发现不少人也遇到过,实在蛋疼。但今天这个不能算是一个bug,因为IE可能是从安全角度上考虑结果导致的。一步步来解读。
upload.php代码:
其实就是打印获取到的文件信息。我们测试一下,选择文件后,提交到PHP页面结果如下:
Array
(
[name] => 7.jpg
[type] => image/jpeg
[tmp_name] => /tmp/php0VkjPG
[error] => 0
[size] => 36297
)
能正确获取文件信息,只需要cp下就能保存。
页面上就只看见a标签
![](http://static.oschina.net/uploads/img/201406/26132409_Ug5J.jpg)
点击“上传文件”弹开选择文件的窗口
![](http://static.oschina.net/uploads/img/201406/26132409_i2Ey.jpg)
选择文件后,正确传送文件信息到服务器
![](http://static.oschina.net/uploads/img/201406/26132410_UQkc.jpg)
这样就完成文件上传了,这个操作在Chrome,FireFox下都正常,IE下有问题。
![](http://static.oschina.net/uploads/img/201406/26132410_0kBz.jpg)
但选择文件后,却不能上传,同时还报一个“拒绝访问”错误,如截图中红圈部分
![](http://static.oschina.net/uploads/img/201406/26132410_3N5H.jpg)
![](http://static.oschina.net/uploads/img/201406/26132411_GGyW.jpg)
最终页面代码如下:
页面:
![](http://static.oschina.net/uploads/img/201406/26132411_2y97.jpg)
需要注意几个问题
1、取消a标签onclick事件,因为实际上已经不需要a标签的onclick触发file的click了,而是直接就点击到file;
2、file标签不需要再设置display:none隐藏,而是通过opacity:0让它完全透明,实际它是浮在a标签之上
3、file标签设置position:absolute后要给left:0、top:0,否则file标签不会吻合覆盖a标签导致点击按钮的时候点不到file标签
我们再来测试一下:
点击按钮:
![](http://static.oschina.net/uploads/img/201406/26132411_4V9K.jpg)
选择文件:
![](http://static.oschina.net/uploads/img/201406/26132411_vCjI.jpg)
上传成功!
又是IE的一个问题,近来是跟IE浏览器磕上了,这个问题发现不少人也遇到过,实在蛋疼。但今天这个不能算是一个bug,因为IE可能是从安全角度上考虑结果导致的。一步步来解读。
普通上传例子
首先普通的文件上传呢,很简单,前端代码:1 2 3 4 5 6 7 8 9 10 11 12 13 | <!DOCTYPE html> < html > < head > < meta charset = "utf-8" /> < title >file标签隐藏</ title > </ head > < body > < form action = "http://192.168.1.99/upload/upload.php" method = "post" enctype = "multipart/form-data" > < input onchange = "document.forms[0].submit();" type = "file" name = "file" /> </ form > </ body > </ html > |
1 2 3 | echo '<pre>' ; print_r( $_FILES [ "file" ]); echo '</pre>' ; |
Array
(
[name] => 7.jpg
[type] => image/jpeg
[tmp_name] => /tmp/php0VkjPG
[error] => 0
[size] => 36297
)
能正确获取文件信息,只需要cp下就能保存。
用别的按钮替代file标签
但是默file标签很难看,而且每个浏览器下都有很大差距。因此我们基本都把真正的file标签给隐藏,然后创建一个标签来替代它,比如我们创建一个a标签来替代它,隐藏file标签,单击a标签时触发file标签click弹出选择文件窗口。最终页面代码如下:1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | <!DOCTYPE html> < html > < head > < meta charset = "utf-8" /> < title >file标签隐藏</ title > </ head > < body > < form action = "http://192.168.1.99/upload/upload.php" method = "post" enctype = "multipart/form-data" style = "display:none;" > < input onchange = "document.forms[0].submit();" type = "file" name = "file" /> </ form > < a onclick = "document.forms[0].file.click();" href = "javascript:void(0);" >上传文件</ a > </ body > </ html > |
![](http://static.oschina.net/uploads/img/201406/26132409_Ug5J.jpg)
点击“上传文件”弹开选择文件的窗口
![](http://static.oschina.net/uploads/img/201406/26132409_i2Ey.jpg)
选择文件后,正确传送文件信息到服务器
![](http://static.oschina.net/uploads/img/201406/26132410_UQkc.jpg)
这样就完成文件上传了,这个操作在Chrome,FireFox下都正常,IE下有问题。
IE不能上传文件
IE下也能正常弹开选择文件的窗口![](http://static.oschina.net/uploads/img/201406/26132410_0kBz.jpg)
但选择文件后,却不能上传,同时还报一个“拒绝访问”错误,如截图中红圈部分
![](http://static.oschina.net/uploads/img/201406/26132410_3N5H.jpg)
解决IE下不能上传文件的问题
其实这是IE安全限制问题,没有点击file的浏览按钮选择文件都不让上传,既然IE非得要亲自点击,我们可以变通一下,让自定义按钮存在又能真正点击到file标签。解决方案是让file标签盖在a标签上,但file是透明的,这样用户看到的是a标签的外观,实际点击是file标签。如图:![](http://static.oschina.net/uploads/img/201406/26132411_GGyW.jpg)
最终页面代码如下:
1 2 3 4 5 | < a style = "position:relative;display:block;width:100px;height:30px;background:#EEE;border:1px solid #999;text-align:center;" href = "javascript:void(0);" >上传文件 < form action = "http://192.168.1.99/upload/upload.php" method = "post" enctype = "multipart/form-data" > < input style = "position:absolute;left:0;top:0;width:100%;height:100%;z-index:999;opacity:0;" onchange = "document.forms[0].submit();" type = "file" name = "file" /> </ form > </ a > |
![](http://static.oschina.net/uploads/img/201406/26132411_2y97.jpg)
需要注意几个问题
1、取消a标签onclick事件,因为实际上已经不需要a标签的onclick触发file的click了,而是直接就点击到file;
2、file标签不需要再设置display:none隐藏,而是通过opacity:0让它完全透明,实际它是浮在a标签之上
3、file标签设置position:absolute后要给left:0、top:0,否则file标签不会吻合覆盖a标签导致点击按钮的时候点不到file标签
我们再来测试一下:
点击按钮:
![](http://static.oschina.net/uploads/img/201406/26132411_4V9K.jpg)
选择文件:
![](http://static.oschina.net/uploads/img/201406/26132411_vCjI.jpg)
上传成功!
相关文章推荐
- IE input file隐藏不能上传文件解决方法
- IE input file隐藏不能上传文件解决方法
- IE input file隐藏不能上传文件解决方法
- IE input file隐藏不能上传文件解决方法(转载)
- IE input file隐藏不能上传文件解决方法
- IE input file隐藏不能上传文件解决方法
- IE中无法使用隐藏input file上传文件
- 上传文件 隐藏input type="file",用text显示
- 上传文件,用js回调函数实现隐藏input type="file"
- 上传文件 隐藏input type="file",用其它标签实现
- 使用input type=file标签进行文件上传时,在安卓手机中的微信浏览器中不能调起相机,但是在苹果手机中的微信浏览器中可以调用相机。解决办法很简单, <input type="file" nam
- 用jQuery重置用于文件上传的input (type="file")
- js 实现 <input type="file" /> 文件上传
- 在IE中必须点击input file 控件的浏览按钮才能提交上传,否则没有权限 。js文件报拒绝访问,解决办法是将input file控件定位到你要点击的地方 ,并且input file做成透明的
- IE and FireFox使用JavaScript清空上传控件input type="file"
- IE type=file上传文件浏览弹窗问题
- [置顶] js 实现 <input type="file" /> 文件上传
- asp.net/c# 用<input type="file" />实现文件上传,multipart/form-data
- 解决美化后的文件上传控件(type=file),IE和firefox不兼容的问题
- 如何设置上传文件控件 input type="file" 的 默认值