【发布时间】:2021-11-29 17:24:27
【问题描述】:
我正在尝试制作具有视差效果的水平部分。在背景中应该有一个以与页面不同的速度滚动的图像。
问题是:我希望视差元素包含在父元素中,因此父元素的作用类似于子元素的掩码:子元素仅在父元素的边界内可见。
我知道这可以通过将视差元素放在两个元素之间来实现,这些元素的背景在视差元素“上方”并阻挡它,但这种方法不适用于我的情况。
想到的明显想法是使用溢出:隐藏在父级上。然而,这会破坏 3D 变换,因此不会留下任何视差。
如何实现描述的效果?
这是一个代码笔:https://codepen.io/rradarr/full/mdwgard。 我希望红色矩形在带有黑色边框的“视差容器”之外不可见。
* {
margin: 0;
}
html, body {
height: 100%
}
main {
position: relative;
width: 100%;
perspective: 1px;
transform-style: preserve-3d;
overflow-y: auto;
overflow-x: hidden;
height: 100vh;
background-color: blue;
}
.static {
min-height: 800px;
}
.parallax-container {
border: solid black 3px;
height: 600px;
width: 100%;
transform-style: preserve-3d;
position: relative;
}
.parallax-child {
position: relative;
width: 100%;
height: 100%;
transform: translateZ(-2px) scale(2.01);
z-index: -1;
}
#img-or-whatever {
height: 900px;
width: 100%;
background-color: red;
position: relative;
z-index: -1;
}
<main>
<div class="static"></div>
<div class="parallax-container">
<div class="parallax-child">
<div id="img-or-whatever"></div>
</div>
</div>
<div class="static"></div>
</main>
【问题讨论】: