CSS3变形倾斜一个侧面

43

是否可以创建“CSS3变换倾斜单侧”?

我找到了一个解决方案,但对我没有用,因为我需要使用图像作为背景(而不是颜色)。

#skewOneSide {
    border-bottom: 40px solid #FF0000;
    border-left: 50px solid rgba(0, 0, 0, 0);
    height: 0;
    line-height: 40px;
    width: 100px;
}

即使这个JsFiddle也不太有用(倾斜的区域应该是透明的)

5个回答

39

试试这个:

为了去除倾斜的影响,使用嵌套的div标签对图像进行处理,并赋予相反的倾斜值。例如,如果父元素设置了20度的倾斜角度,则可以在嵌套的(图像)div中设置-20度的倾斜值。

.container {
  overflow: hidden;
}

#parallelogram {
  width: 150px;
  height: 100px;
  margin: 0 0 0 -20px;
  -webkit-transform: skew(20deg);
  -moz-transform: skew(20deg);
  -o-transform: skew(20deg);
  background: red;
  overflow: hidden;
  position: relative;
}

.image {
  background: url(http://placekitten.com/301/301);
  position: absolute;
  top: -30px;
  left: -30px;
  right: -30px;
  bottom: -30px;
  -webkit-transform: skew(-20deg);
  -moz-transform: skew(-20deg);
  -o-transform: skew(-20deg);
}
<div class="container">
  <div id="parallelogram">
    <div class="image"></div>
  </div>
</div>

例子:

http://jsfiddle.net/diegoh/mXLgF/1154/


1
@darthmaim的回答(如下)建议使用伪元素(before或after)来偏移内部边框,该答案应被接受。无需任何额外的包装元素。 - Clifford Fajardo

33

也许你想使用 CSS 的 "clip-path" 属性(可以用于透明度和背景)

"clip-path" 参考文献:https://developer.mozilla.org/en-US/docs/Web/CSS/clip-path

生成器: https://bennettfeely.com/clippy/

示例:

/* With percent */
.element-percent {
  background: red;
  width: 150px;
  height: 48px;
  display: inline-block;
  
  clip-path: polygon(0 0, 100% 0%, 75% 100%, 0% 100%);
}

/* With pixel */
.element-pixel {
  background: blue;
  width: 150px;
  height: 48px;
  display: inline-block;
  
  clip-path: polygon(0 0, 100% 0%, calc(100% - 32px) 100%, 0% 100%);
}

/* With background */
.element-background {
  background: url(https://images.pexels.com/photos/170811/pexels-photo-170811.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=750&w=1260) no-repeat center/cover;
  width: 150px;
  height: 48px;
  display: inline-block;
  
  clip-path: polygon(0 0, 100% 0%, calc(100% - 32px) 100%, 0% 100%);
}
<div class="element-percent"></div>

<br />

<div class="element-pixel"></div>

<br />

<div class="element-background"></div>


2
这是目前最好的处理方法。演示很棒,我给赞了。 - Obsidian Age

16

你可以使用transform和transform-origin来实现这个效果。

组合不同的变换可以得到类似的结果。希望您会发现这些例子对简单的变换有所帮助。这里有一个左侧点:

div {    
    width: 300px;
    height:200px;
    background-image: url('');
    -webkit-transform: perspective(300px) rotateX(-30deg);
    -o-transform: perspective(300px) rotateX(-30deg);
    -moz-transform: perspective(300px) rotateX(-30deg);
    -webkit-transform-origin: 100% 50%;
    -moz-transform-origin: 100% 50%;
    -o-transform-origin: 100% 50%;
    transform-origin: 100% 50%;
    margin: 10px 90px;
}
<div></div>

这是右偏点:

div {    
    width: 300px;
    height:200px;
    background-image: url('');
    -webkit-transform: perspective(300px) rotateX(-30deg);
    -o-transform: perspective(300px) rotateX(-30deg);
    -moz-transform: perspective(300px) rotateX(-30deg);
    -webkit-transform-origin: 0% 50%;
    -moz-transform-origin: 0% 50%;
    -o-transform-origin: 0% 50%;
    transform-origin: 0% 50%;
    margin: 10px 90px;
}
<div></div>

transform: 0% 50%; 的作用是将元素的原点设置为垂直中心和水平左侧。因此,图像的左侧部分不可见透视效果,看起来是平的。右侧部分存在透视效果,因此看起来是倾斜的。


1
这会使图像失真。 - skyegill

13

我知道这篇文章有点老了,但我想建议使用线性渐变来代替边距偏移来实现相同的效果。这样可以保持任何内容在其原始位置。

http://jsfiddle.net/zwXaf/2/

HTML

<ul>
    <li><a href="#">One</a></li>
    <li><a href="#">Two</a></li>
    <li><a href="#">Three</a></li>
</ul>

CSS

/* reset */
ul, li, a {
    margin: 0; padding: 0;
}
/* nav stuff */
ul, li, a {
    display: inline-block;
    text-align: center;
}
/* appearance styling */
ul {
    /* hacks to make one side slant only */
    overflow: hidden;
    background: linear-gradient(to right, red, white, white, red);
}
li {
    background-color: red;
     transform:skewX(-20deg);
    -ms-transform:skewX(-20deg);
    -webkit-transform:skewX(-20deg);
}
li a {
    padding: 3px 6px 3px 6px;
    color: #ffffff;
    text-decoration: none;
    width: 80px;
     transform:skewX(20deg);
    -ms-transform:skewX(20deg);
    -webkit-transform:skewX(20deg);
}

10

您可以尝试使用:before伪元素来实现您的需求,只需要将边框样式改为倾斜即可:http://jsfiddle.net/Hfkk7/1101/

补充说明:您实现边框的方法也是可行的,唯一做错的是将伪元素放在了div上面,导致透明边框没有显示出来。如果您将伪元素定位到div左侧,那么同样可以成功实现效果:http://jsfiddle.net/Hfkk7/1102/


这几乎完成了我所需的工作,但是这里的倾斜也会使背景图像倾斜,有没有解决方法。无论如何,加上+1感谢 :) - Syed

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接