整理了2种方法,看完确定以为超简单~css
1、旋转型html
话很少说先看下须要的样式:web
1.transform:rotate(angle)post
2.overflowui
3.visibilityspa
html结构:3d
<body> <div class="box1"> <div class="box2"> <div class="box3"> <p>随心所欲随心所欲</p> </div> </div> </div> </body>
3层div,结构是否是很简单~接下来要怎么旋转呢?code
为了方便理解加了背景orm
box1:红色
box2:黑色
box3:粉色
1.box1旋转120°,box2旋转-60°,box3再旋转-60°,咱们的内容放在box3中。
2.通过旋转确定有超出的部分,对3个div都设置overflow:hidden。
3.box1,box2是用来旋转获得6边形的,因此对他们设置visibility: hidden,box3放内容,需显示,所以设置visibility: visible。
(若是不对box3设置visibility: visible;它会继承box2的visibility: hidden; )
注意div的宽高不要相等,否则获得的就不是6边形咯。
通过旋转和对超出部分的隐藏就获得咱们想要的6边形了,全部代码以下:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>CSS3—六边形</title> <style type="text/css"> .box1, .box2, .box3 { width: 200px; height: 250px; overflow: hidden; } .box1, .box2 { visibility: hidden; } .box1 { transform: rotate(120deg); -ms-transform: rotate(120deg); -moz-transform: rotate(120deg); -webkit-transform: rotate(120deg); } .box2 { transform: rotate(-60deg); -ms-transform: rotate(-60deg); -moz-transform: rotate(-60deg); -webkit-transform: rotate(-60deg); } .box3 { transform: rotate(-60deg); -ms-transform: rotate(-60deg); -moz-transform: rotate(-60deg); -webkit-transform: rotate(-60deg); background-color:pink; visibility: visible; } .box3 p{ color: yellow; font-size: 22px; line-height: 200px; text-align: center; } </style> </head> <body> <div class="box1"> <div class="box2"> <div class="box3"> <p>随心所欲随心所欲</p> </div> </div> </div> </body> </html>
2、拼接型
很明显2个三角形加1个矩形,是否是很简单~
三角形请看上一篇:CSS3—三角形
代码以下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>css—六边形2</title> <style> .triangleb{ width:0; height:0; border-top:0px solid transparent; border-right:60px solid transparent; border-bottom:40px solid pink; border-left:60px solid transparent; } .trianglet{ width:0; height:0; border-top:40px solid pink; border-right:60px solid transparent; border-bottom:0px solid transparent; border-left:60px solid transparent; } .box{ width: 120px; height: 65px; background-color: pink; } </style> </head> <body> <div class="triangleb"></div> <div class="box"></div> <div class="trianglet"></div> </body> </html>
博客园:CSS3—六边形