>  기사  >  웹 프론트엔드  >  CSS 실용적인 팁: 시차를 사용하여 멋진 대화형 효과 얻기

CSS 실용적인 팁: 시차를 사용하여 멋진 대화형 효과 얻기

青灯夜游
青灯夜游앞으로
2022-10-10 18:42:232883검색

CSS 실용적인 팁: 시차를 사용하여 멋진 대화형 효과 얻기

이 기사에서는 CSS를 사용하여 스크롤 시차 효과를 얻는 약간의 요령을 소개하고 이 요령을 사용하여 흥미로운 대화형 특수 효과를 만듭니다. [학습 동영상 공유: css 동영상 튜토리얼, 웹 프론트엔드]

CSS를 사용하여 스크롤 시차 효과를 얻는 것과 관련하여 특정 솔루션을 자세히 설명하는 이전 기사가 있습니다. - CSS를 사용하여 시차 효과를 얻습니다. 관심 있는 학생들은 먼저 이 글을 확인해 보세요.

여기서는 순수한 CSS 시차 기술이 사용됩니다.

transform:translate3d를 사용하여 스크롤 시차를 얻습니다.

transform: translate3d 实现滚动视差

这里利用的是 CSS 3D,实现滚动视差效果。

原理就是:

  • 我们给容器设置上 transform-style: preserve-3dperspective: xpx,那么处于这个容器的子元素就将位于3D空间中,

  • 再给子元素设置不同的 transform: translateZ(),这个时候,不同元素在 3D Z轴方向距离屏幕(我们的眼睛)的距离也就不一样

  • 滚动滚动条,由于子元素设置了不同的 transform: translateZ(),那么他们滚动的上下距离 translateY 相对屏幕(我们的眼睛),也是不一样的,这就达到了滚动视差的效果。

关于 transform-style: preserve-3d 以及 perspective 本文不做过多篇幅展开,默认读者都有所了解,还不是特别清楚的,可以先了解下 CSS 3D。

核心代码表示就是:

<div>
    <div>translateZ(-1)</div>
    <div>translateZ(-2)</div>
    <div>translateZ(-3)</div>
</div>
html {
    height: 100%;
    overflow: hidden;
}

body {
    perspective: 1px;
    transform-style: preserve-3d;
    height: 100%;
    overflow-y: scroll;
    overflow-x: hidden;
}

.g-container {
    height: 150%;

    .section-one {
        transform: translateZ(-1px);
    }
    .section-two {
        transform: translateZ(-2px);
    }
    .section-three {
        transform: translateZ(-3px);
    }
}

总结就是父元素设置 transform-style: preserve-3dperspective: 1px,子元素设置不同的 transform: translateZ,滚动滚动条,效果如下:

CSS 실용적인 팁: 시차를 사용하여 멋진 대화형 효과 얻기

CodePen Demo -- CSS 3D parallax

很明显,当滚动滚动条时,不同子元素的位移程度从视觉上看是不一样的,也就达到了所谓的滚动视差效果。

借助 CSS 视差实现酷炫交互动效

OK,有了上面的铺垫,我们来看看这样两个有趣的交互效果。由群里的日服第一切图仔 wheatup 友情提供。

先来看第一个效果:

效果是一种文本交替在不同高度的层展示,并且在滚动的过程中,会有明显的 3D 视差效果。

这个效果并不困难,核心就在于:

  • 利用了 transform-style: preserve-3dperspective 构建不同的层次效果,制作视差效果

  • 利用元素的 ::before::after 构建了 3D 的效果

我们看一个最小化 DEMO:

<div>
    <div></div>
    <div></div>
    <div></div>
</div>
.g-container {
    height: 150vh;
    perspective: 600px;
}

.g-box {
    width: 200px;
    height: 200px;
    background: #999;
    transform-style: preserve-3d;

    &::before,
    &::after {
        content: "";
        position: absolute;
        right: 0;
        left: 0;
        transform-style: preserve-3d;
        height: 200px;
        background-color: #ccc;
    }
    &::before {
        transform-origin: top center;
        top: 0;
        transform: rotateX(-90deg);
    }
    &::after {
        transform-origin: bottom center;
        bottom: 0;
        transform: rotateX(90deg);
    }
}

滚动 g-container 容器,即可得到一种 3D 效果:

由于还需要视差效果,我们需要给不同的层赋予不同的 translateZ(),我们稍微改造下代码,给每个 g-box 中间,再加多一层正常的 div,再给每个 g-box 加上一个 translateZ()

<div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
</div>
.g-container {
    width: 400px;
    height: 150vh;
    perspective: 800px;
}

.g-normal {
    width: 200px;
    height: 200px;
    background: #666;
    transform-style: preserve-3d;
}

.g-box {
    width: 200px;
    height: 200px;
    background: #999;
    transform-style: preserve-3d;
    transform: translate3d(0, 0, 200px);

    &::before,
    &::after {
        // ... 保持不变
    }
}
  • 由于 g-boxg-normal 的 translateZ 值不同,所以滚动的过程中会出现视差效果

  • 由于 g-boxtranslateZ 值为 translateZ(200px),两个伪元素的 rotateX 为正负 90deg,且高度为 200px,因此 g-boxg-normal 刚好可以通过 g-box여기서 사용되는 것은 스크롤 시차 효과를 얻기 위해 CSS 3D입니다.

  • 원칙은 다음과 같습니다.

위 내용은 CSS 실용적인 팁: 시차를 사용하여 멋진 대화형 효과 얻기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제