200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > html css 正六边形 css画正六边形

html css 正六边形 css画正六边形

时间:2022-04-18 15:15:52

相关推荐

html css 正六边形 css画正六边形

说下两种css 制作正六边形的方法。

先看一下结果:

在之前要先了解一下正六边形内角和边的关系,正六边形的每个内角是60deg,如图(√3其实是根号3):

方法一:原理把正六边形分成三部分,左中右分别是:before部分,div部分,after部分,如图:

before三角形部分是div的before伪元素,after三角形部分是div的after伪元素。

html代码:

css代码:

.div {

position: relative;

width: 50px;

height: 86.6px;

margin: 50px auto;

background-color: red;

}

.div:before {

content: '';

display: block;

position: absolute;

width: 0;

height: 0;

right:50px;

border-width: 43.3px 25px;

border-style: solid;

border-color: transparent red transparent transparent;

}

.div:after {

content: '';

display: block;

position: absolute;

width: 0;

height: 0;

left:50px;

border-width: 43.3px 25px;

border-style: solid;

border-color: transparent transparent transparent red;

top:0;

}

注意div及伪元素的宽高需要根据上面的公式计算。

方法二:也是把正六边形分成三个宽高相同的div,然后使用定位以及css3 transform:rotate分别向左右旋转60deg形成正六边形,如图:

html代码:

css代码:

1 .one {

2 width: 50px;

3 height: 86.6px;

4 margin: 0 auto;

5 border-top: 1px solid red;

6 border-bottom: 1px solid red;

7 }

8 .two {

9 position: absolute;

10 width: 50px;

11 height: 86.6px;

12 left: 25px;

13 top: 0;

14 transform: translate(-50%,-50%);

15 transform: rotate(60deg);

16 border-top: 1px solid red;

17 border-bottom: 1px solid red;

18 }

19 .three {

20 position: absolute;

21 width: 50px;

22 height: 86.6px;

23 left: 25px;

24 top: 0;

25 transform: translate(-50%,-50%);

26 transform: rotate(300deg);

27 border-top: 1px solid red;

28 border-bottom: 1px solid red;

29 }

以上两种方法,元素的宽高尺寸以及左右位移需要根据上面的公式计算不能随意填写

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。