基于view-timeline 实现滚动驱动动画

前言

最近接到一个做网站官网的需求,官网的页面元素需要有一些动画效果,来增加页面的活力。很多网站的官网都有一个共同的特点,就是滚动页面的时候,页面上的元素会有一些出场动画效果,比如元素的移动、旋转、缩放、透明度变化等等,这些动画效果都是通过滚动页面来驱动的,这种方式可以让页面看起来更加的生动,也可以让用户更加的有参与感,这种方式也是一种很好的用户体验。

动画效果

设计小姐姐在提供动画效果示例的时候,让我参考github的官网,github的官网的动画效果是这样的:

可以看到页面在滚动到这个模块的时候,这个模块的标题、内容和左侧的进度条都有动画效果,其中标题和内容是从左侧滑动进来的,而且有一个透明度的变化,进度条是从上向下增加高度的,这样的动画效果看起来很酷炫,而且也很有层次感。

实现思路

我们可以看到,这个动画效果是由滚动页面来驱动的,当页面滚动到这个模块的时候,这个模块的标题、内容和左侧的进度条才会有动画效果。

说到滚动驱动动画,自然想到了比较新的css属性 view-timeline,这个属性可以让我们在滚动到某个元素时,根据元素和视口的相对位置来控制动画的进度,这个属性的使用方法可以参考这里

接下来,我们来用 view-timeline 来实现这个动画效果。

  1. 定义我们需要的元素,如下图所示:

整块区域添加class section,标题部分元素 class 为section-title,描述部分为section-des,进度条为section-progress

  1. 定义动画效果

侧滑的动画效果:

css 复制代码
@keyframes slideInLeft {
  from {
    transform: translateX(-15px);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

进度条的动画效果:

css 复制代码
@keyframes progress {
  from {
    transform-origin: top;
    transform: scaleY(0);
  }
  to {
    transform-origin: top;
    transform: scaleY(100%);
  }
}
  1. 给 section 元素添加 view-timeline 属性
css 复制代码
.section {
  view-timeline: --sectionReveal;
}
  1. 给标题、描述和进度条添加 对应的动画效果
css 复制代码
.section-title {
    animation-timeline: --sectionReveal;
    animation-name: slideInLeft;
    animation-range: entry 40% entry 60%;
    animation-fill-mode: both;
  }
  .section-des {
    animation-timeline: --sectionReveal;
    animation-name: slideInLeft;
    animation-range: entry 50% entry 70%;
    animation-fill-mode: both;
  }
  .section-progress {
    animation-timeline: --sectionReveal;
    animation-name: progress;
    animation-range: entry 50% entry 70%;
    animation-fill-mode: both;
  }

在上面的代码中,我们指定了动画的时间轴 --sectionReveal,然后给标题、描述和进度条添加了对应的动画效果,这样当页面滚动到这个模块的时候,这个模块的标题、描述和进度条就会有动画效果了。

其中值得注意的是 animation-range 这个属性,我们可以通过这个属性指定动画的开始时间和结束时间,比如 animation-range: entry 50% entry 70%;指定了动画开始时机为:section 元素进入视口的 50% 时刻,动画结束时机为:section 元素进入视口的 70% 时刻。可以通过指定不同的开始时机,让动画有层次感。

最后看看效果:

是不是和github 官网的效果差不多呢

最后

view-timeline 这个属性还是比较新的,浏览器的支持度不是特别高,所以在实际项目中使用的时候,还需要考虑兼容性的问题。那么不用这种方式,又该如何实现这个类似的效果呢?

我是viewer,下篇文章里,介绍使用 intersectionObserver + Tailwind CSS 来实现这个动画效果。欢迎点赞,收藏,评论。

相关推荐
铭毅天下5 分钟前
EasySearch Rules 规则语法速查手册
开发语言·前端·javascript·ecmascript
GISer_Jing16 分钟前
AI Agent操作系统架构师:Harness Engineer解析
前端·人工智能·ai·aigc
英俊潇洒美少年25 分钟前
css中专门用来提升渲染性能、减少重排重绘的属性
前端·css
天若有情67338 分钟前
前端HTML精讲01:别再乱 div 一把抓,吃透语义化标签才是进阶第一步
前端·html
Highcharts.js39 分钟前
React 开发者的图表库生态:Highcharts React
前端·react.js·前端框架
阿部多瑞 ABU39 分钟前
文明文化悖论
前端·人工智能·ai写作
钛态1 小时前
Flutter 三方库 react 泛前端核心范式框架鸿蒙原生层生态级双向超能适配:跨时空重塑响应式单向数据流拓扑与高度精密生命周期树引擎解耦视图渲染控制中枢(适配鸿蒙 HarmonyOS ohos)
前端·flutter·react.js
全栈前端老曹1 小时前
【前端地图】地图开发基础概念——地图服务类型(矢量图、卫星图、地形图)、WGS84 / GCJ-02 / BD09 坐标系、地图 SDK 简介
前端·javascript·地图·wgs84·gcj-02·bd09·地图sdk
只与明月听1 小时前
RAG深入学习之向量数据库
前端·人工智能·python
吕不说1 小时前
AI 面试总挂?可能是表达出了问题:三层表达法 + STAR 进阶框架
前端