正三角形
正三角形不需要用到伪元素,只需要设定p自身的边框宽度即可发生,先来看一下正三角形的边长与中线,若边长为100px,则中线四舍五入就是87px(100 x sin(60)= 87)。
因而我们要将p的长宽都设为0,接着把底部border的宽度设为87px,摆布的border宽度设为50px(色彩设为通明transparent),就能够做出一个美丽的三角形。
width:0; height:0; border-width:0 50px 87px ; border-style:solid; border-color:transparent transparent #095;
正方形
正方形应该是最简朴的,只需设定长宽设定为一样数值就能够了,不过实在另有别的两种要领,第一种你能够把长宽设为0,把高低摆布的border设为50px也能够,第二种则是高度设为0,宽度设为100px,然后某个边宽也设为100,都是能够的。
.a{ width:100px; height:100px; background:#c00; } .b{ width:0; height:0; border-width:50px; border-style:solid; border-color:#095; } .c{ width:100px; height:0; border-width:0 0 100px; border-style:solid; border-color:#069; }
正五边形
正五边形就需要进入基础的三角函数范畴了,让我们先把正五边形剖析,用底本的p作为上方的三角形,然后用一个伪元素制造下方的梯形,由于正五边形每边的夹角为108度,所以能够藉由三角函数盘算出上方三角形的高度为59px(100 x cos(54)),宽度为192px(100x sin(54)x 2),下方梯形的高度为95px(100 x sin(72)),长边的宽度跟上面的三角形一样都是192px。
相识道理以后,就能够应用伪元夙来搭配制造啰!
.a{ position:relative; width:0; height:0; border-width:0 81px 59px; border-style:solid; border-color:transparent transparent #069; } .a:before{ position:absolute; content:""; top:59px; left:-81px; width:100px; height:0; background:none; border-width:95px 31px 0; border-style:solid; border-color:#069 transparent transparent; }
正六边形
正六边形的每一个夹角是120度,假如以纯CSS的方向来看的话,就是把正五边形上面的三角形转变一下,就能够做出正六边形,也就是变成高低两个梯形的组合罢了,梯形的长边为200px(100 x cos(60)x 2 + 100),梯形的高度为87px(100 x sin(60))。
所以只需把正五边形的CSS稍作修正就能够做出正六边形了。
.a{ position:relative; width:100px; height:0; border-width:0 50px 87px; border-style:solid; border-color:transparent transparent #f80; } .a:before{ position:absolute; content:""; top:87px; left:-50px; width:100px; height:0; background:none; border-width:87px 50px 0; border-style:solid; border-color:#f80 transparent transparent; }
正七边形
正七边形最先就必须再运用after这个伪元素了,由于正七边形必需要拆解为三个内存块,分别是用底本的p作为上面的三角形,一个伪元素作为中心的梯形,然后另一个伪元素作为底部的梯形,正七边形的夹角比较迥殊不是整数,而是128又4/7度,也许取到小数第二位是128.57,所以盘算起来效果就如下图所示,重点就是必需要清楚地晓得长宽是多少。
有了长宽以后,就最先用CSS来写啰!
.a{ position:relative; width:0; height:0; border-width:0 90px 43px; border-style:solid; border-color:transparent transparent #09c; } .a:before{ position:absolute; content:""; top:140px; left:-112px; width:100px; height:0; border-width:78px 62px 0; border-style:solid; border-color:#09c transparent transparent; } .a:after{ position:absolute; content:""; top:43px; left:-112px; width:180px; height:0; border-width:0 22px 97px; background:none; border-style:solid; border-color:transparent transparent #09c; }
正八边形
正八边形实在就是把正七边形上面的三角形变成梯形,然后中心的梯形变成矩形就搞定了,正八边形的夹角为135度,盘算出来的各个地区长宽如下图。
一样的相识道理,CSS做起来就简朴多啰!
.a{ position:relative; width:100px; height:0; border-width:0 71px 71px; border-style:solid; border-color:transparent transparent #f69; } .a:before{ position:absolute; content:""; top:171px; left:-71px; width:100px; height:0; border-width:71px 71px 0; border-style:solid; border-color: #f69 transparent transparent; } .a:after{ position:absolute; content:""; top:71px; left:-71px; width:242px; height:0; border-width:0 0 100px; background:none; border-style:solid; border-color:transparent transparent #f69; }
小结
以上就是地道应用CSS做出来的单一div的正多边形变更,假如闇练的话,实在加上动画效果,就能够做出像下面示例这个模样的变更动画啰!
相干教程:css视频教程
以上就是CSS 怎样举行单一div的正多边形变更的细致内容,更多请关注ki4网别的相干文章!