• CSS 滚动驱动动画 view()


    CSS 滚动驱动动画 view()

    animation-timeline 通过 view() 表示一个元素 A 将提供匿名的、 用来控制动画的 view progressive timeline.

    通过 A 在其最近的滚动祖先元素中的可见性来推动 view progressive timeline. 也就是, 当 A 即将出现在滚动祖先元素时, timeline0%, 当 A 完全离开滚动祖先元素时, timeline100%.

    上图

    在这里插入图片描述

    语法

    view() 可以接收两个参数

    • axis: 轴, 可以是 block(默认值), inline, y, x. 与 scroll() 相同, 可点击参考. 📖 如果指定轴的方向不可以滚动, 那么时间线将始终处于 0% 的状态.

    • inset: 默认情况, 动画是元素将要进入滚动容器开始, 在完全离开滚动容器结束. inset 参数可以修改动画开始和结束时位置, 也就是元素滚动到哪里算开始、又滚动到哪里算结束.

      • inset 可以是一个值或两个值, 可以是 auto 或长度值或百分比值.

    📖 这两个参数的位置可以任意, 且两个参数都不是必须, 因此下面的调用都是合理的.

    📖 注意参数之间使用空格而不是逗号分隔

    • view():
    • view(block):
    • view(20px):
    • view(inline 20px):
    • view(inline 20px 10%):

    两个 inset

    <div class="container">
      <div class="box">div>
    div>
    
    • 1
    • 2
    • 3
    .container {
      width: 400px;
      height: 200px;
      overflow: auto;
    }
    @keyframes grow1 {
      from { transform: scaleX(0); }
      to { transform: scaleX(1); }
    }
    .box {
      width: 50%;
      height: 20px;
      background-color: salmon;
      animation: grow1 linear both;
      animation-timeline: view(block 40% 20%);
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    在这里插入图片描述

    我们仔细观察, 当动画开始的时候, 是距离底部 20% 高度的位置开始, 到距离顶部 40% 的位置结束.

    一个 inset

    如果像下面一样只有一个值, 表示动画从距离底部 40% 的位置开始, 到距离顶部 40% 的位置结束. 也就是 40% 被复用了.

    .box {
      animation-timeline: view(block 40%);
    }
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    当然如果你想要动画从默认位置开始, 或默认位置结束, 那么就使用 auto

    • view(block 40% auto): 默认位置开始, 距顶部 40% 位置结束

      • 在这里插入图片描述
    • view(block auto 40%): 距底部 40% 位置开始, 默认位置结束

      • 在这里插入图片描述

    💡所以你看到规律了吗? 如果百分比写在第一个位置, 就是相对于 顶部; 如果写在二个位置, 就是相对于 底部

    谢谢你看到这里😊

  • 相关阅读:
    正则表达式,你不会用太可惜
    2-爬虫-代理池搭建、代理池使用(搭建django后端测试)、爬取某视频网站、爬取某视频网站、bs4介绍和遍历文档树
    js设计模式:桥接模式
    2022牛客多校联赛第八场 题解
    数学建模经验分享会For浙商大管工学院
    纯血鸿蒙来了,企业开发者应该关注什么
    Kaldi 入门使用教程
    OpenCv——鼠标事件笔记
    逆向WeChat(三)
    实时3D渲染如何加速汽车线上体验应用推广
  • 原文地址:https://blog.csdn.net/broken_promise/article/details/132773754