input元素[type="file"]时的款式订制及访问器适配

这两天在做老百姓网的笔试题的情况下遇到了这样1个难题,用 HTML5 的新特点完成老百姓网现有的1个控制模块,在老百姓网中逛了1阵后最后选定了公布信息内容所用的表单控制模块,缘故很简易,在 HTML5 中对于表单有许多新特点可使用,这些新特点也很有好用性,终究有表单的地区确实是太多了,例如申请注册啦,登陆啦,发帖啦......(喂,有点跑题了亲。)


这个情况下,我看到初始网页页面中的表单里有这么个元素


我的第1反映便是,哈,input元素罢了,用CSS订制1下款式便可以了,随后我很当然的提前准备“右键”-“核查元素”看来看实际的款式老百姓网是如何写的之后发现......


1定是我的开启方法不对......既然这样,自然是自身动手能力衣食无忧了,有1点我能够确定的是,这类提交文档的表单控制跑不上是要用input[type="file"]的,好吧,立即加上这么1行编码:

拷贝编码
编码以下:

<input type="file" />

在chrome访问器中更新看看:


没什么疑惑,这是预设的款式,并且我发现这类预设的款式还很不太好改动,最使人恼火的是,不一样的访问器预设的款式全是不1样的,借用在网上的1张照片就很清晰了:


(因此我就说嘛,你们这些访问器1点都不聪明,相互之间又不太好好沟通交流,自high得非常爽,苦的但是前端开发的同学啊你妹)
但是方法還是很好想起的,用1个元素把 input 包裹起来,在元素中加上所必须的别的元素,并设定款式,做成必须做到的实际效果,将 input 元素的 position 值设为 absolute 填充外围元素,再将 input 全透明便可。
HTML编码以下:

拷贝编码
编码以下:

<div id="input-file">
<span id="text">点一下提交</span>
<input id="file" type="file" />
</div>

对应的CSS编码以下:

拷贝编码
编码以下:

#input-file {
position: relative; /* 确保子元素的精准定位 */
width: 120px;
height: 30px;
background: #eee;
border: 1px solid #ccc;
text-align: center;
cursor: pointer;
}
#text {
display: inline-block;
margin-top: 5px;
color: #666;
font-family: "黑体";
font-size: 18px;
}
#file {
display: block;
position: absolute;
top: 0;
left: 0;
width: 120px; /* 宽高和外围元素维持1致 */
height: 30px;
opacity: 0;
-moz-opacity: 0; /* 适配旧式访问器 */
filter: alpha(opacity=0); /* 适配IE */
}

显示信息实际效果如图:

kimoji......
8过,这里仍有1个bug,作为成这样的按钮时,当电脑鼠标悬停时应当是可点一下情况,但即便给全部元素都加上了 cursor: pointer; 特性,依然会有一些地区显示信息为指针情况,有木有大神可以处理呢?