使用css画一个文件上传图案
如下图,如果是你,你会怎么实现:
通常我们会通过字体图标来显示中间的加号,外层用一个div包裹即可;或者使用伪元素来模拟中间的一横一竖,这都比较麻烦。
其实我们可以直接使用div+css就可以实现。
轮廓属性outline
outline属性是用来设置一个或多个单独的轮廓属性的简写属性 , 例如 。
轮廓有下面几个属性:
{ outline-style: solid; outline-width: 10px; outline-color: red; }
他们有一种简写形式:
{ outline: 10px solid red; }
轮廓的特点
轮廓不占据空间,它们被描绘于内容之上。
可以做到下图的效果:
我发现,当设置 outline-offset 为负值的时候,轮廓会出现在div的内部,如果继续扩大其负值,最终轮廓会收缩成一个“➕”加号,正好可以作为文件上传样式中间的加号。
这就有意思了,于是代码就来了:
div { margin: 100px; width: 100px; height: 100px; outline: 15px solid #545454; outline-offset: -66px; border: 2px solid #545454; }
outline-offset: -66px; 是关键,它表示轮廓距div边的距离,如果为负值则会往里面收缩,最后形成一个加号。具体上传样式的大小和outline的宽度都需要自己慢慢调整已达到大和谐。
需要注意的是:
容器得是个正方形
outline 边框本身的宽度不能太小
原文github仓库地址:https://github.com/Daotin/front-end-notes/issues
总结
以上所述是小编给大家介绍的使用css画一个文件上传图案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
相关文章
css input[type=file] 样式美化(input上传文件样式 )
这篇文章主要介绍了css input[type=file] 样式美化(input上传文件样式 )的相关资料,需要的朋友可以参考下2018-06-20基于jQuery+CSS3实现带动画效果文件上传插件特效源码
基于jQuery+CSS3实现带动画效果文件上传插件特效源码是一款基于jQuery+CSS3实现的上传界面,支持文件拖到上传动画代码。本段特效源码可以在各大网站使用,有需要的朋友直接2017-07-10HTML5+CSS3实现无插件拖拽上传图片(支持预览与批量)
本篇文章主要介绍了HTML5+CSS3实现无插件拖拽上传图片(支持预览与批量),现在html5提供了API以及File,FileReader,XMLHttpRequest等强大的API,为我们拖放实现上传提供2017-01-05- 文件上传input在各个浏览器里表现形式都不一样,这里通过css样式控制,尽量在多浏览器中的表现都一样2013-01-10
- 文件上传类型表单是一个让很多前端开发者纠结过的表单类型,因为它是一个无法单纯用CSS给它定义兼容的样式。2011-06-20
- 表单上传文件的“浏览”按钮修改代码,需要的朋友可以参考下。2011-05-03
最新评论