工作中需要自定义一个上传按钮,看了张鑫旭的文章,才想到当初可以用lable给input type=file设计样式。
(转)原文来自 http://www.zhangxinxu.com/wordpress/2015/11/html-input-type-file/
有一种方法是这样的:
让file类型的元素透明度0,覆盖在我们好看的按钮上。然后我们去点击好看的按钮,实际上点击是是file元素。
然而,此方法有一些不足:
尺寸控制不灵活。CSS width属性有些浏览器不管用,需要使用size,然后高度控制也不精准,我们很难正好覆盖在好看的自定义按钮上。
样式不好控制,按钮的hover态以及active态不好处理。
HTML结构限制以及定位成本。
更好的方法是,使用label元素与file控件关联,好处在于:
点击自定义的漂亮按钮就是点击我们file控件;
没有尺寸控制不精确的问题;
没有不能响应hover态active态的问题;
我们的漂亮按钮甚至可以在form表单元素的外面,例如:
<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>
而直接用lable 把input包住,不需要加for="xFile"
,点击lable部分就是点input.
<label class="btn btn-primary">Buscar
<input type="file" style="display:none"/>
</label>
效果如下:
见原文:http://www.zhangxinxu.com/wordpress/2015/11/html-input-type-file/