此文转载至 http://lililucky1211.iteye.com/blog/1916129javascript
1. label for 绑定元素响应事件,例如 点击label能够执行绑定的input 的button的事件,php
label实现了好看的效果,可是因为ie安全限制问题,会拒绝非file浏览上传文件的访问,因此处理方法应该是让file附在lable的上面,而后是透明处理,直接点击file便可。html
2. 转上传文件的隐藏处理:前端
又是IE的一个问题,近来是跟IE浏览器磕上了,这个问题发现很多人也遇到过,实在蛋疼。但今天这个不能算是一个bug,由于IE多是从安全角度上考虑结果致使的。一步步来解读。java
首先普通的文件上传呢,很简单,前端代码:浏览器
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
>
|
upload.php代码:安全
1
2
3
|
echo
'<pre>'
;
print_r(
$_FILES
[
"file"
]);
echo
'</pre>'
;
|
其实就是打印获取到的文件信息。咱们测试一下,选择文件后,提交到PHP页面结果以下:服务器
Array
(
[name] => 7.jpg
[type] => image/jpeg
[tmp_name] => /tmp/php0VkjPG
[error] => 0
[size] => 36297
)post
能正确获取文件信息,只须要cp下就能保存。测试
可是默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
>
|
页面上就只看见a标签
点击“上传文件”弹开选择文件的窗口
选择文件后,正确传送文件信息到服务器
这样就完成文件上传了,这个操做在Chrome,FireFox下都正常,IE下有问题。
IE下也能正常弹开选择文件的窗口
但选择文件后,却不能上传,同时还报一个“拒绝访问”错误,如截图中红圈部分
其实这是IE安全限制问题,没有点击file的浏览按钮选择文件都不让上传,既然IE非得要亲自点击,咱们能够变通一下,让自定义按钮存在又能真正点击到file标签。解决方案是让file标签盖在a标签上,但file是透明的,这样用户看到的是a标签的外观,实际点击是file标签。如图:
最终页面代码以下:
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
>
|
页面:
须要注意几个问题
一、取消a标签onclick事件,由于实际上已经不须要a标签的onclick触发file的click了,而是直接就点击到file;
二、file标签不须要再设置display:none隐藏,而是经过opacity:0让它彻底透明,实际它是浮在a标签之上
三、file标签设置position:absolute后要给left:0、top:0,不然file标签不会吻合覆盖a标签致使点击按钮的时候点不到file标签
咱们再来测试一下:
点击按钮:
选择文件:
上传成功!