HTML input type=file 样式设计

工作中需要自定义一个上传按钮,看了张鑫旭的文章,才想到当初可以用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/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。