如果需要背景图像,如何用CSS剪角?

时间:2017-09-20 09:37:17

标签: html css border cornerradius

enter image description here

嘿,伙计们,上面是我正在研究的项目的图像。这是我得到了多远:

enter image description here

创建盒子非常简单;但是,现在我没有IDEA如何在左下角创建这个切角。我已经尝试了很多东西,如果背景不是透明的,而是一块颜色,大多数东西都可以工作。由于背景需要是这个图像,我不能让切角在没有一面显示某种颜色的情况下工作。这是我的代码:

<div class="profile">
    // HTML content
</div>

<style>
   profile {
   border: 2px solid #fff;
   color: #fff;
   height: 100%;
   padding: 10px;
   width: 250px;
</style>

我已经尝试了很多东西,例如这里(不是我使用的确切代码,但我按照这个例子):

.cut {
  border: none;
  position: relative;
}

.cut:before {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  border-bottom: 20px solid lightgrey;
  border-left: 20px solid #e67e22;
  width: 0;
}

这会创建一个切角,但是有一个纯色块,我需要显示图像,而不是颜色。

有没有人知道如何做到这一点?建议非常感谢。谢谢!

3 个答案:

答案 0 :(得分:1)

您可以使用前/后元素来制作这样的底部:

.profile {
position:relative;
display:inline-block;
margin:50px;
border:1px solid #000;
border-bottom:none;
width:100px;
height:200px;
background:#ccc;
}
.profile:after {
content:" ";
position:absolute;
border:1px solid #000;
height:20px;
width:80px;
bottom:-20px;
right:-1px;
border-top:0;
border-left:0;
background:#ccc;
}
.profile:before {
content:" ";
position:absolute;
border-bottom:1px solid #000;
height:29px;
width:29px;
transform:rotate(45deg);
bottom:-15px;
left:6px;
background:#ccc;
}
<div class="profile"></div>

底部被分成两个部分:一个只有两个边框的矩形+一个边框,一个边框旋转45°

希望有所帮助

注意:更改尺寸时要小心

答案 1 :(得分:1)

&#13;
&#13;
.profile {
  position: relative;
  display: inline-block;
  width: 200px;
  height: 200px;
  border-top: 2px solid #000;
  border-left: 2px solid #000;
  border-right: 2px solid #000;
  padding: 20px;
  box-sizing: border-box;
  font-family: Arial, sans-serif;
}

.profile h2 {
  margin: 0 0 10px;
}

.profile p {
  font-size: 14px;
}

.profile .bottom {
  position: absolute;
  bottom: -30px;
  right: -2px;
  width: 180px;
  height: 30px;
  border-bottom: 2px solid #000;
  box-sizing: border-box;
  border-right: 2px solid #000;
}

.profile .bottom::before {
  content: '';
  position: absolute;
  left: -10px;
  bottom: -4px;
  width: 2px;
  height: 35px;
  background-color: #000;
  transform: rotate(-35deg);
}
&#13;
<div class="profile">
  <h2>Name</h2>
  <p>Description</p>
  <div class="bottom"></div>
</div>
&#13;
&#13;
&#13;

答案 2 :(得分:0)

我认为你正试图削减图像的角落而不是div,所以你可以这样做:

&#13;
&#13;
body {
    background: url('https://www.lunapic.com/editor/premade/o-paint-bucket.gif');
}

.container {
    display: inline-block;
    width: 200px;
    height: 300px;
    overflow: hidden;
}

.container .image_container {
    width: 320px;
    height: 550px;
    overflow: hidden;
    display: block;
    position: relative;
    transform: rotate(45deg);
    margin-left: calc(260px - 360px);
    margin-top: -40px;
}

.container .image_container .image {
    transform: rotate(-45deg);
    margin-top: 10px;
    margin-left: -10px;
}
&#13;
<div class="container">
  <div class="image_container">
    <div class="image">
      <img src="https://www.w3schools.com/css/img_fjords.jpg" />
    </div>
  </div>
</div>
&#13;
&#13;
&#13;