0

我正在尝试在CSS3中制作 3d 功能区框,但遇到了一些问题,所以我怎样才能用最少的代码用纯CSS制作它。

这是我正在尝试制作的图像......

在此处输入图像描述

谢谢

4

1 回答 1

7

这是一种方法,非常少的标记。 :before:after伪元素需要 IE 8+,如果您需要支持较低的 (IE6/7),您可以<div>为三角形角使用两个额外的元素。

示例 jsfiddle

HTML:

<div id="box">
    <div id="ribbon">3d Text and rounded corner sample</div>
</div>​

CSS:

#box {
    position:relative;
    background:gray;
    width:400px;
    height:300px;
    margin:20px 45px;
}
#ribbon {
    position:absolute;
    top:15px;
    left:-20px;
    width:360px;
    height:55px;
    background:#ff2702;
    color:white;
    padding:20px 40px;
    font-size:24px;
    font-weight:bold;
    border-radius:5px 5px 0 0;
    box-shadow:0 0 8px #333;
    text-shadow:0 0 8px #000;
}
#ribbon:before {
    content:'';
    position:absolute;
    bottom:-20px;
    left:0;
    border-top:solid 10px #ff2702;
    border-right:solid 10px #ff2702;
    border-bottom:solid 10px transparent;
    border-left:solid 10px transparent;
}
#ribbon:after {
    content:'';
    position:absolute;
    bottom:-20px;
    right:0;
    border-top:solid 10px #ff2702;
    border-right:solid 10px transparent;
    border-bottom:solid 10px transparent;
    border-left:solid 10px #ff2702;
}
​
于 2012-05-02T07:31:53.990 回答