36

是否可以创建“CSS3 Transform Skew One Side”

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

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

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

4

5 回答 5

34

尝试这个:

取消倾斜图像,请为图像使用嵌套 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/

于 2013-12-11T12:21:42.347 回答
21

也许您想使用 CSS“剪辑路径”(适用于透明度和背景)

“剪辑路径”参考: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>

于 2018-10-02T22:57:46.070 回答
15

您可以使用变换和变换原点来实现。

结合各种变换可以得到类似的结果。我希望你觉得这对你有帮助。:) 有关更简单的转换,请参阅这些示例。这已经离开了一点:

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%;将原点设置为元素的垂直中间和水平左侧。因此在图像的左侧看不到透视图,因此看起来很平坦。透视效果在右边部分,所以看起来是倾斜的。

于 2015-03-12T08:45:06.553 回答
14

我知道这是旧的,但我想建议使用线性渐变来实现相同的效果而不是边距偏移。这将在其原始位置保留任何内容。

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);
}
于 2014-07-11T06:28:05.213 回答
9

您尝试使用:before非常接近,您唯一需要更改的是实际上使用倾斜而不是边框​​:http: //jsfiddle.net/Hfkk7/1101/

编辑:您的边框方法也可以,您唯一做错的事情是在您的 div 顶部放置了 before 元素,因此没有显示透明边框。如果您将伪元素放置在 div 的左侧,那么一切都会正常工作:http: //jsfiddle.net/Hfkk7/1102/

于 2013-11-04T03:35:09.923 回答