怎样使用纯CSS3创建一个简单的五角星图形

html-css062

怎样使用纯CSS3创建一个简单的五角星图形,第1张

我们可以使用SVG、Canvas、CSS3或者背景图片来实现五角星图案及其悬停效果。

CSS3引入的伪元素和变换特性使得实现五角星图形非常简单,并且可以结合渐变实现更为漂亮的效果。

因此使用图片实现五角星已经毫无必要(图片占用额外的请求,且数据量大。除非要支持低版本的桌面IE浏览器)。

首先我们创建一个三角形,这通常是使用带大尺寸边线而零内容尺寸的元素来实现,代码示范:

.tri { width: 0height: 0border-left: 15px solid transparentborder-right: 15px solid transparentborder-bottom: 30px solid red}

第二步,我们使用伪元素:after和:before来克隆2个同样大小的三角形。

.tri:after,.tri:before { width: 0height: 0border-left: 15px solid transparentborder-right: 15px solid transparentborder-bottom: 30px solid red}

然后,我们在上述2个伪元素上分别应用不同的旋转变换:

.tri:before { transform: rotate(70deg)}.tri:after { transform: rotate(-70deg)}

这样我们就实现了一个五角星图形(图标)。我们可以用类似的方法实现更多的几何形状。

先说方法步骤:

首先创建一个三角形,使用带大尺寸边线而零内容尺寸的元素来实现。

使用伪元素:after和:before来克隆2个同样大小的三角形。

在上面所说的2个伪元素上分别应用不同的旋转变换来达到五角星效果。

代码如下:

<!--创建三角形-->

.tri {

width: 0

height: 0

border-left: 15px solid transparent

border-right: 15px solid transparent

border-bottom: 30px solid red

}

<!--使用伪类元素-->

.tri:after,.tri:before {

width: 0

height: 0

border-left: 15px solid transparent

border-right: 15px solid transparent

border-bottom: 30px solid red

}

<!--旋转-->

.tri:before {

transform: rotate(70deg)

}

.tri:after {

transform: rotate(-70deg)

}

#star-five {

   margin: 60px 0

   position: relative

   display: block

   color: red

   width: 0px

   height: 0px

   border-right:  100px solid transparent

   border-bottom: 70px  solid red

   border-left:   100px solid transparent

   -moz-transform:    rotate(35deg)

   -webkit-transform: rotate(35deg)

   -ms-transform:     rotate(35deg)

   -o-transform:      rotate(35deg)

}

#star-five:before {

   border-bottom: 80px solid red

   border-left: 30px solid transparent

   border-right: 30px solid transparent

   position: absolute

   height: 0

   width: 0

   top: -45px

   left: -65px

   display: block

   content: ''

   -webkit-transform: rotate(-35deg)

   -moz-transform:    rotate(-35deg)

   -ms-transform:     rotate(-35deg)

   -o-transform:      rotate(-35deg)    

}

#star-five:after {

   position: absolute

   display: block

   color: red

   top: 3px

   left: -105px

   width: 0px

   height: 0px

   border-right: 100px solid transparent

   border-bottom: 70px solid red

   border-left: 100px solid transparent

   -webkit-transform: rotate(-70deg)

   -moz-transform:    rotate(-70deg)

   -ms-transform:     rotate(-70deg)

   -o-transform:      rotate(-70deg)

   content: ''

}

<div id="star-five"></div>