3

*{
  margin:0; padding: 0;
}
body {
 background-color: orangered;
}
.content {
  margin-top: 200px;
  height: 100vh;
  background-color: #fdfdff;
}
.tilt {
  position: relative;
}
.tilt:before {
  content: '';
    padding-top: 8.74887%;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 100%;
    background-image: linear-gradient(5deg, #fdfdff calc(50% - 1px), transparent 50%);
}
<div class="content tilt">

</div>

似乎 IE11 在理解 calc() css 属性方面存在一些问题。

我以这种方式使用带有线性梯度的 calc:

background-image: linear-gradient(5deg, #fdfdff calc(50% - 1px), transparent 50%);

但是当我这样使用它时:

background-image: linear-gradient(5deg, #fdfdff, transparent 50%);

它可以正常工作。

还有一件事我不明白。当我在 IE11 中检查该属性时,将其关闭并重新打开即可。

使用 calc(50% - 1px) 的重点是角度看起来更平滑,就是这样。

有什么建议么?

4

1 回答 1

3

我找到了解决方案。在我的 sass mixin 中,我添加了:

@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) { background: linear-gradient($angle, $color 50%, transparent 50%); }

现在它可以按我的意愿工作。

于 2017-06-11T10:48:55.733 回答