如何用css制作前卫角落

时间:2013-02-18 00:58:06

标签: html css

有谁知道如何制作前卫角落,如下所示?看看边缘如何环绕角落。我也想知道这个术语(如果有的话)。跨浏览器支持(IE8及以上,奖金IE7)是必须的。谢谢你的帮助。

enter image description here

3 个答案:

答案 0 :(得分:3)

结帐this tutorial。我不知道它是如何与crossbrowser兼容的(因为它是CSS3),但它实现了你想要的效果。

HTML:

<div>
    <h2></h2>
</div>

CSS:

div {
    width: 200px;
    padding: 50px;
    margin: 0 auto;
    border: 1px solid #333;
}

h2 {
    position: relative;
    width: 50%;
    height: 50px;
    margin: 30px 10px 10px -70px;
    background-color: orange;
}

h2:after {
    content: ' ';
    position: absolute;
    width: 0;
    height: 0;
    left: 0px;
    top: 100%;
    border-width: 5px 10px;
    border-style: solid;
    border-color: #666 #666 transparent transparent;
}

JS Fiddle Example

答案 1 :(得分:0)

.box{
    background: #666;
    border: 4px solid #fff;
    box-shadow: 0px 0px 20px #000;
    width: 200px;
    height: 200px;
    margin: 40px auto;
    position: relative;
}

.ribbon{
    background: #FFA500;
    position: absolute;
    width: 100%;
    top: 20px;
    left: -20px;
    height: 20px;
    padding-right: 20px;
}

.ribbon::before{
    content: '';
    position: absolute;
    left: 0px;
    top: 20px;
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 0 16px 10px 0;
    border-color: transparent #FFA500 transparent transparent;    
    z-index: -5;
}

HTML:

<div class="box">
    <div class="ribbon"></div>
</div>

DEMO

我不认为IE 7/8支持::before伪元素,所以如果你想要IE兼容性添加另一个元素并在其上放置::before样式:)

答案 2 :(得分:0)

edgy corner实际上只有div triangle,您只需 ONE 元素即可。

<div id="myCorner"></div>

myCorner 将是div, myCorner:之后将是三角形。

检查出来:http://jsfiddle.net/Starx/Xp6E7/2/

enter image description here

#myCorner
{
    width:100px;
    height:70px;
    background-color:orange;
     -webkit-box-shadow: 0 4px 5px -3px black;
       -moz-box-shadow: 0 4px 5px -3px black;
            box-shadow: 0 4px 5px -3px black;
    position:relative;

}

#myCorner:after
{
    content:"";    
    position:absolute;
    left: 0;
    top:100%;
    width: 0px;
    height: 0px;
    border-style:solid;
    border-width: 5px 10px;
    border-color: orange orange transparent transparent;
    z-index: -1;
}