CSS 滚动驱动动画 view()

  • [CSS 滚动驱动动画 view](#CSS 滚动驱动动画 view "#css-%E6%BB%9A%E5%8A%A8%E9%A9%B1%E5%8A%A8%E5%8A%A8%E7%94%BB-view")
    • 语法
    • 例子
      • [两个 inset](#两个 inset "#%E4%B8%A4%E4%B8%AA-inset")
      • [一个 inset](#一个 inset "#%E4%B8%80%E4%B8%AA-inset")

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

html 复制代码
<div class="container">
  <div class="box"></div>
</div>
css 复制代码
.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%);
}

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

一个 inset

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

css 复制代码
.box {
  animation-timeline: view(block 40%);
}

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

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

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

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

谢谢你看到这里😊

相关推荐
GIS之路2 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒3 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
Kagol4 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉4 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau4 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生4 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼4 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范
明君879974 小时前
Flutter 如何给图片添加多行文字水印
前端·flutter
helloweilei4 小时前
CSS进阶: background-clip
css
leolee185 小时前
Redux Toolkit 实战使用指南
前端·react.js·redux