5分钟彻底搞懂Border画多边形原理

在网上看到大神用border属性来讲div变成三角形,梯形等等各种形状。也详细解释了原理,我看了半天也弄懂了。接下来这篇我希望能用5分钟让前端小白们毫无压力的彻底理解这个原理,这样以后要用的时候也不懂百度了,画个草图直接开写。

第一步:理解盒子模型中的border

先看图:
盒子模型
这里,我分别标出了4个边框

border-top   //red
border-left  //green
border-right //yellow
border-bottom //blur

这里可以明显的看出,实际上我们的border,是一个等腰梯形。

第二步:当长宽为0?

接下来,我们设置:

.div{
	//让div的长宽为0
	width:0px;
	height:0px;
}

令一个div的长宽都是0。此时这个div可以看近似做是一个无限小的点。并且这个div的content和padding都是0。此时如果我们放大这个div,看到的会是这样的:
这里写图片描述
可以看到其中的content和padding都是0所以没有了。所以4个边框变成了4个等腰三角形。
其中白色的线的长度,就是border-bottom的线宽。

第三步:设置线宽和透明色

接下来设置:

	//设置
	border-left: 50px solid transparent;
    border-right: 50px solid transparent;
    border-bottom: 100px solid red;

上边的设置中,50 100 分别是线宽。
transparent表示设置为透明色。
结果:
这里写图片描述
最后我们得到的三角形的蓝色部分,完全是由border-bottom以一己之力构成的。

虚线围起来的白色区域是设置为透明的border-left和border-right。实际上是看不到的。

在图中可以看出,只要改变两个50px,就可以自由的改变三角形的顶点的位置

明白了这个原理,就可以轻松构成其他方向的任意三角形,梯形等等了。

只要给上边的样式增加一个宽度,就可以变成梯形

border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-bottom: 100px solid red;
width: 200px; // 注意这里的宽度,首先要>100,不然当然还是三角形
  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值