膜拜!用最少的代码却实现了最牛逼的滚动动画

今天带领大家学习如何使用最少的代码创建令人叹为观止的滚动动画~

在聊ScrollTrigger插件之前我们先简单了解下GSAP

GreenSock 动画平台 (GSAP) 可为 JavaScript 可以操作的任何内容(CSS 属性、SVG、React、画布、通用对象等)动画化,并解决不同浏览器上存在的兼容问题,而且比 jQuery快 20 倍。大约1000万个网站和许多主要品牌都在使用GSAP。

接下来小师妹带领大家一起学习ScrollTrigger插件的使用。

插件简介

ScrollTrigger是基于GSAP实现的一款高性能页面滚动触发HTML元素动画的插件。

通过ScrollTrigger使用最少的代码创建令人叹为观止的滚动动画。我们需要知道ScrollTrigger是基于GSAP实现的插件,ScrollTrigger是处理滚动事件的,而真正处理动画是GSAP,二者组合使用才能实现滚动动画~

插件特点

  • 将任何动画链接到特定元素,以便它仅在视图中显示该元素时才执行该动画。
  • 可以在进入/离开定义的区域或将其直接链接到滚动栏时在动画上执行操作(播放、暂停、恢复、重新启动、反转、完成、重置)。
  • 延迟动画和滚动条之间的同步。
  • 根据速度捕捉动画中的进度值。
  • 嵌入滚动直接触发到任何 GSAP 动画(包括时间线)或创建独立实例,并利用丰富的回调系统做任何您想做的事。
  • 高级固定功能可以在某些滚动位置之间锁定一个元素。
  • 灵活定义滚动位置。
  • 支持垂直或水平滚动。
  • 丰富的回调系统。
  • 当窗口调整大小时,自动重新计算位置。
  • 在开发过程中启用视觉标记,以准确查看开始/结束/触发点的位置。
  • 在滚动记录器处于活动状态时,如将active类添加到触发元素中:toggleClass: "active"
  • 使用 matchMedia() 标准媒体查询为各种屏幕尺寸创建不同的设置。
  • 自定义滚动触发器容器,可以定义一个 div 而不一定是浏览器视口。
  • 高度优化以实现最大性能。
  • 插件大约只有6.5kb大小。

安装/引用

CDN

<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.8.0/gsap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.8.0/ScrollTrigger.min.js"></script>

ES Modules

import { gsap } from "gsap";
import { ScrollTrigger } from "gsap/ScrollTrigger";

gsap.registerPlugin(ScrollTrigger);

UMD/CommonJS

import { gsap } from "gsap/dist/gsap";
import { ScrollTrigger } from "gsap/dist/ScrollTrigger";

gsap.registerPlugin(ScrollTrigger);

简单示例

gsap.to(".box", {
  scrollTrigger: ".box", // start the animation when ".box" enters the viewport (once)
  x: 500
});

高级示例

let tl = gsap.timeline({
    // 添加到整个时间线 
    scrollTrigger: {
      trigger: ".container",
      pin: true,   // 在执行时固定触发器元素
      start: "top top", // 当触发器的顶部碰到视口的顶部时
      end: "+=500", // 在滚动 500 px后结束
      scrub: 1, // 触发器1秒后跟上滚动条
      snap: {
        snapTo: "labels", // 捕捉时间线中最近的标签
        duration: {min: 0.2, max: 3}, // 捕捉动画应至少为 0.2 秒,但不超过 3 秒(由速度决定) 
        delay: 0.2, // 从上次滚动事件开始等待 0.2 秒,然后再进行捕捉 
        ease: "power1.inOut" // 捕捉动画的过度时间(默认为“power3”) 
      }
    }
  });

// 向时间线添加动画和标签 
tl.addLabel("start")
  .from(".box p", {scale: 0.3, rotation:45, autoAlpha: 0})
  .addLabel("color")
  .from(".box", {backgroundColor: "#28a92b"})
  .addLabel("spin")
  .to(".box", {rotation: 360})
  .addLabel("end");

自定义示例

ScrollTrigger.create({
  trigger: "#id",
  start: "top top",
  endTrigger: "#otherID",
  end: "bottom 50%+=100px",
  onToggle: self => console.log("toggled, isActive:", self.isActive),
  onUpdate: self => {
    console.log("progress:", self.progress.toFixed(3), "direction:", self.direction, "velocity", self.getVelocity());
  }
});

接下来,我们一起来看使用ScrollTrigger可以实现怎样的效果吧。




在这里插入图片描述

利用ScrollTrigger可以实现很多炫酷的效果,还有更多示例及源代码

ScrollTrigger官方地址:https://greensock.com/scrolltrigger/

ScrollTrigger示例地址:https://greensock.com/st-demos/

更多项目源码关注Github:https://github.com/frontslab/front-daily

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 您可以通过说出赞美的话,或者向他表示您的敬意来向他膜拜。例如:“gzn真是太厉害了,我真的很佩服你。”或者“gzn,你真的很优秀,我想向你学习。”但是,膜拜他人可能会让您看起来很不自信,所以我建议您可以尝试学习他的优秀之处,并努力成为一个更优秀的人。 ### 回答2: 如果你觉得一个叫gzn的人很强,想要膜拜他,以下是一些建议: 1. 尊重他:向gzn表达你对他的尊敬和赞赏,对他的成就和才能表示钦佩。遇到他时,礼貌地与他交谈,并注意言行举止的得体和尊重。 2. 学习他的优点:了解gzn的优秀之处,并从中学习。看看他取得成功的原因,是否是他的刻苦努力、智慧决策或者他在某个领域的专业知识。尝试模仿他的行为和思考方式,研究并学习他的成功之道。 3. 向他请教:如果有机会,向gzn提出问题,寻求他的建议和指导。尊重地向他表达你的兴趣,并请教他在某个领域中的经验和见解。展示你对他的学习态度和对他智慧的崇拜。 4. 支持他的事业:如果gzn有自己的事业或项目,你可以尽力支持和关注他的努力和成果。参与他的项目,分享他的成就,为他的事业助力。这样,你不仅可以表达你的钦佩之情,还能够与他建立更紧密的联系。 5. 自我成长:尽管你想向gzn学习,但也要保持自己的独立思考和个性。不要完全模仿他,而是将他的优点和经验与你自己的才能和兴趣结合起来。追求自己的成长,并为自己设定目标,努力成为一个强大而有原创力的个体。 最重要的是,膜拜他不仅仅是以身体力行,更是通过行动向他证明你是一个值得尊敬和关注的人。承担起积极向上的行为和责任,以自己的努力和成就来回报他的关注和期待。 ### 回答3: 如果你觉得一个叫gzn的人很强,想要向他膜拜,你可以考虑以下几点: 1. 尊重与赞美:向gzn表示对他所取得成就的钦佩和赞美,这是最基本的表达方式之一。尊敬他的才华和技能,并且以谦逊和真诚的态度向他表达你的敬意。 2. 学习与模仿:观察gzn的行为和习惯,尝试学习他的成功之道。了解他取得成就的原因,从他的经验中汲取灵感,将其运用到自己的生活中。努力追求自己的目标,并向gzn学习如何提升自己的能力和技巧。 3. 合作与交流:如果你有机会与gzn进行交流或合作,抓住这个机会。分享自己的观点和想法,与他探讨各种话题,寻求他的建议和指导。与gzn建立良好的合作关系,有助于你从他的经验中获益。 4. 成为他人的榜样:通过向身边的人展示你对gzn的尊敬和模仿,成为他人的榜样。在自己的生活和工作中发挥积极的影响力,传递正能量,鼓励他人追求自己的目标和理想。这样的行为也能够向gzn表达你对他的敬意。 不管你选择了哪种方式,保持真诚和谦虚的态度非常重要。膜拜并不意味着盲目崇拜,而是对别人的才华和成就表示敬意,并从中获得启发与动力。记住要相信自己的潜力,努力发展自己的实力,成为更好的自己。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一条苍老的小鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值