有人知道如何编码框的边框(右上角和左下角)(下图)? 希望您能够帮助我。 提前致谢!
这是HTML
<div class="carouselle">
<div class="carousel-item">
<div class="xx_b">
<p>« Lorem ipsum dolor sit amet, feugiat delicata liberavisse id
cum, no quo maiorum intellegebat, liber regione eu sit.
Mea cu case ludus integre, vide viderer eleifend ex mea. His ay
diceret, cum et atqui placerat... »</p>
</div>
<span class="t_author">Tom Cruz</span>
<span class="t_occupation">Famous Movie Star</span>
</div>
</div>
这是CSS
.carouselle .carousel-item .xx_b:after {
-moz-border-bottom-colors: none;
-moz-border-left-colors: none;
-moz-border-right-colors: none;
-moz-border-top-colors: none;
border-color: #eee transparent transparent;
border-image: none;
border-right: 10px solid transparent;
border-style: solid;
border-width: 10px;
bottom: -20px;
content: "";
margin-left: -10px;
position: absolute;
}
.carouselle .carousel-item .xx_b {
background: none repeat scroll 0 0 #eee;
border: 15px solid #cccccc;
box-sizing: border-box;
float: left;
height: 100%;
margin-bottom: 30px;
padding: 50px 150px;
position: relative;
width: 100%;
}
答案 0 :(得分:5)
最好使用box-shadow
来创建上述效果而不是伪元素和边框。我们需要两个框阴影,一个用于顶部和左侧区域,另一个(inset
框阴影)用于右侧和底部区域。
可以通过修改框阴影的大小来调整边界区域的厚度。
.carouselle .carousel-item .xx_b {
background: none repeat scroll 0 0 #eee;
box-shadow: -15px -15px 0px #cccccc, inset -15px -15px 0px #cccccc;
box-sizing: border-box;
float: left;
height: 100%;
margin: 10px 0px 30px 10px;
padding: 50px 150px;
position: relative;
width: 100%;
}
&#13;
<div class="carouselle">
<div class="carousel-item">
<div class="xx_b">
<p>« Lorem ipsum dolor sit amet, feugiat delicata liberavisse id cum, no quo maiorum intellegebat, liber regione eu sit. Mea cu case ludus integre, vide viderer eleifend ex mea. His ay diceret, cum et atqui placerat... »</p>
</div>
<span class="t_author">Tom Cruz</span>
<span class="t_occupation">Famous Movie Star</span>
</div>
</div>
&#13;
答案 1 :(得分:2)
要获得此效果,我们可以将border
与box-shadow
结合使用。 border
属性将用于两个边框(顶部和右侧或左侧,或底部和右侧或左侧),box-shadow
将用于其他两个。
最后,我们需要在边缘上引入一个边距,该边距有阴影来抵消元素的宽度,因为box-shadow
不会影响元素的宽度。元件。
div {
border-top: 15px solid #cccccc;
border-right: 15px solid #cccccc;
box-shadow: 15px 15px 0 1px #cccccc;
margin: 0 15px 15px 0;
}
div {
background: #eee;
height: 100px;
border-top: 15px solid #cccccc;
border-left: 15px solid #cccccc;
box-shadow: 15px 15px 0 1px #cccccc;
margin: 0 15px 15px 0;
}
&#13;
<div></div>
&#13;
答案 2 :(得分:2)
这是使用两个叠加的伪元素作为背景的另一种方法。在以下示例中,&#34; border&#34;响应:
p {
position: relative;
width: 80%;
margin: 50px auto;
padding: 4%;
text-align: center; color: #fff;
}
p:before,p:after {
content: '';
position: absolute;
top: 0; left: 0;
width: 100%; height: 100%;
background: grey;
opacity: 0.5;
z-index: -1;
}
p:before {
margin: -0.5% 0 0 -0.5%;
}
p:after {
margin: 0.5% 0 0 0.5%;
}
&#13;
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis ultrices commodo ligula, sed venenatis metus sollicitudin nec. Maecenas vestibulum porttitor tempus.
</p>
&#13;
如jbutler483所述,使用一个伪元素和rgba()
颜色可以实现相同的输出,用于背景透明度:
p{
width:80%;
margin:50px auto;
padding:5% 4% 4% 5%;
position:relative;
text-align:center;
color:#fff;
background: rgba(0, 0, 0, 0.2);
}
p:before{
content:'';
position:absolute;
background:inherit;
width:100%; height:100%;
left:0; top:0;
margin: 1% 0 0 1%;
z-index:-1;
}
&#13;
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis ultrices commodo ligula, sed venenatis metus sollicitudin nec. Maecenas vestibulum porttitor tempus.
</p>
&#13;
答案 3 :(得分:1)
.container {
width:600px;
}
p {
background: #A1A1A1;
padding:25px;
font-size:12px;
box-shadow: -5px -5px 0px #ccc, inset -5px -5px 0px #ccc;
color:#fff;
}
<div class="container">
<p>« Lorem ipsum dolor sit amet, feugiat delicata liberavisse id
cum, no quo maiorum intellegebat, liber regione eu sit.
Mea cu case ludus integre, vide viderer eleifend ex mea. His ay
diceret, cum et atqui placerat... »</p>
</div>