因为<input type="file" />太丑,一般的解决方案是,让file类型的元素透明度为0,覆盖在咱们漂亮的按钮上。而后咱们去点击好看的按钮,实际上点击的是file元素。
html
然而,此方法有不少的不足:浏览器
一、尺寸控制不灵活。CSS width
属性有些浏览器无论用,须要使用size
,而后高度控制也不精准,咱们很难正好覆盖在好看的自定义按钮上。ide
二、样式很差控制,按钮的hover
态以及active
态很差处理。wordpress
三、HTML结构限制以及定位成本。ui
更好的办法是,使用label元素与file控件关联。spa
<label class="ui_button ui_button_primary" for="xFile">上传文件</label> <form> <input type="file" id="xFile" style="position:absolute;clip:rect(0 0 0 0);"> </form>
这样就解决了以上问题。code
本文出自张鑫旭博客:http://www.zhangxinxu.com/wordpress/2015/11/html-input-type-file/orm