网页制作 
首页 > 网页制作 > 浏览文章

使用css画一个文件上传图案

(编辑:jimmy 日期: 2024/11/6 浏览:3 次 )

如下图,如果是你,你会怎么实现:

使用css画一个文件上传图案

通常我们会通过字体图标来显示中间的加号,外层用一个div包裹即可;或者使用伪元素来模拟中间的一横一竖,这都比较麻烦。

其实我们可以直接使用div+css就可以实现。

轮廓属性outline

outline属性是用来设置一个或多个单独的轮廓属性的简写属性 , 例如 。

轮廓有下面几个属性:

{
    outline-style: solid;
    outline-width: 10px;
    outline-color: red;
}

他们有一种简写形式:

{
    outline: 10px solid red;
}

轮廓的特点

轮廓不占据空间,它们被描绘于内容之上。

可以做到下图的效果:

使用css画一个文件上传图案

我发现,当设置 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样式 解决文字过长显示省略号问题
下一篇:CSS 点击radio实现两个图片样式切换并且多个radio中只能有一个checked