Heim  >  Artikel  >  Web-Frontend  >  css中的有趣的 border

css中的有趣的 border

高洛峰
高洛峰Original
2016-11-22 10:54:031300Durchsuche

border

简单来说,就是我们常用的边框,一个非常基础的用法,就是

border: 1px solid black;
// 等价于
border-width: 1px;
border-style: solid;
border-color: black;

下面是演示的效果:

QQ图片20161122092324.png

当然还可以定义很多奇形怪状的边框类型,比如圆角(radius,可能兼容性不是很好),椭圆(其实只要懂了椭圆,边框就可以随意绘制了)。

border 1px solid black;
border-radius: 50%;

QQ图片20161122092324.png

border-top,-right,-bottom,-left

看了这么多有意思的 DEMO,那么对于边框,你真的了解了吗?

最近碰到一个有意思的 CSS 样式,让我对于边框有了很深刻的了解。平时我们用边框,基本都要给边框一个宽度,1px,偶尔2px,并没有发现边框与元素之间的关系,当我们把 border-width换大一点的值,问题就来了。

border: 20px solid gray;

QQ图片20161122092324.png

并且,边框是可以单独设置 top,right,bottom,left 的值:

border: 20px solid gray;
border-top-width: 40px;
border-left-width: 40px;

QQ图片20161122092324.png

边框与边框的交界处该如何来判断呢?

了解这一点非常重要,如果你也发现了这个问题,那么下面有意思的东西就来了:

border: 20px solid;
border-top-color: black;
border-right-color: red;
border-bottom-color: gray;
border-left-color: blue;

QQ图片20161122092324.png

居然是内顶点与外顶点的连线把边框分开了,如果把元素的 width 和 height 都设置成 0,再加一个 radius:

width: 0;
height: 0;
border-radius: 50%;

QQ图片20161122092324.png

前面 border-radius 的原理你也应该懂了吧!

用 border 实现箭头

知道了一些 border 的基本知识,我们就可以实现常见于对话框的箭头,像下面这种:

QQ图片20161122092324.png

这个需要借助于 CSS 中的透明 transparent 来实现,比如我们需要一个向右的箭头,参考上面 width 和 height 为 0 时的例子,对应的边框大小 15px,0px,15px,30px,先看下面这个例子

border-width: 15px 0px 15px 30px;
border-color: black gray;
border-style: solid;

QQ图片20161122092324.png

这个时候需要把 border-top 和 border-bottom 的颜色设置成透明,

border-color: transparent gray;

QQ图片20161122092324.png

那么,对于的其他三个角度的箭头也可以以同样的方式设计出来:

QQ图片20161122092324.png

总结

看了这篇文章,是不是觉得 border 的功能非常强大,其实我们常见的一些气泡和形状都可以用 border 来实现,哈哈,非常鄙视那些用图片的同学。共勉。


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn