html 定制文件选择,input元素[type="file"]时的样式定制及浏览器兼容性问题探讨

这两天在做百姓网的笔试题的时候遇到了这样一个问题,用 HTML5 的新特性实现百姓网现有的一个模块,在百姓网中逛了一阵后最终选定了发布信息所用的表单模块,原因很简单,在 HTML5 中针对表单有很多新特性可以使用,这些新特性也很有实用性,毕竟有表单的地方实在是太多了,比如注册啦,登录啦,发帖啦......(喂,有点跑题了亲。)

6328f5d3ceec0168b8d4e26b6e48875a.png

这个时候,我看到原始网页中的表单里有这么个元素

c1eab3bcd07b3804b28ad273773ed4c2.png

我的第一反应就是,哈,input元素而已,用CSS定制一下样式就可以了,然后我很自然的准备“右键”-“审查元素”来看看具体的样式百姓网是怎么写的以后发现......

13ed53cf9bc8e24faf7ada53f5f96f41.png

8aa52e2251486c8abf9d2f8f4c7790c1.png

一定是我的打开方式不对......既然这样,当然是自己动手丰衣足食了,有一点我可以确认的是,这种上传文件的表单控件跑不了是要用input[type="file"]的,好吧,直接添加这么一行代码:

复制代码代码如下:

在chrome浏览器中刷新看看:

29e53fc873572f4e0dad3b77b2d42d9b.png

8f43a337f85262bbc7455fa1482e4fd6.png

毫无疑问,这是预设的样式,而且我发现这种预设的样式还很不好修改,最让人恼火的是,不同的浏览器预设的样式都是不一样的,借用网上的一张图片就很清楚了:

b844a43ca2172d742edbe2801a13a3bf.png

(所以我就说嘛,你们这些浏览器一点都不听话,彼此之间又不好好沟通,自high得特别爽,苦的可是前端的同学啊你妹)

不过办法还是很好想到的,用一个元素把 input 包裹起来,在元素中添加所需要的其他元素,并设置样式,做成需要达到的效果,将 input 元素的 position 值设为 absolute 填充外围元素,再将 input 透明即可。

HTML代码如下:

复制代码代码如下:

点击上传

对应的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; /* 宽高和外围元素保持一致 */

height: 30px;

opacity: 0;

-moz-opacity: 0; /* 兼容老式浏览器 */

filter: alpha(opacity=0); /* 兼容IE */

}

显示效果如图:

7b1329ed23acfeadeeb3aabcded1a4a7.png

812b6159f7adcac9f3c23ae3e8e69ee4.png

kimoji......

八过,这里仍有一个bug,当做成这样的按钮时,当鼠标悬停时应该是可点击状态,但即使给所有元素都添加了 cursor: pointer; 属性,仍然会有某些区域显示为指针状态,有没有高手能够解决呢?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值