> 웹 프론트엔드 > HTML 튜토리얼 > CSS3-六边形_html/css_WEB-ITnose

CSS3-六边形_html/css_WEB-ITnose

WBOY
풀어 주다: 2016-06-24 11:28:01
원래의
1089명이 탐색했습니다.

整理了2种方法,看完肯定觉得超简单~

一、旋转型

话不多说先看下需要的样式:

1.transform:rotate(angle)

2.overflow

3.visibility

效果:演示效果,runjs

html结构:

<body>    <div class="box1">        <div class="box2">            <div class="box3">                <p>为所欲为为所欲为</p>            </div>        </div>    </div></body>
로그인 후 복사

3层div,结构是不是很简单~接下来要怎么旋转呢?

为了方便理解加了背景

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边形了,所有代码如下:

        CSS3—六边形    <body>    <div class="box1">        <div class="box2">            <div class="box3">                <p>为所欲为为所欲为</p>            </div>        </div>    </div></body>
로그인 후 복사

二、拼接型

看效果:演示效果,runjs

很明显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>
로그인 후 복사

 

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿