前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >animate-timing-function属性的cubic-bezier() 函数比较贝塞尔曲线的快慢

animate-timing-function属性的cubic-bezier() 函数比较贝塞尔曲线的快慢

作者头像
不爱吃糖的程序媛
发布2024-01-18 20:58:51
1670
发布2024-01-18 20:58:51
举报
文章被收录于专栏:夏天的前端笔记

今天前端笔试遇到了一个题考察动画animate-timing-function属性的cubic-bezier() 函数,比较贝塞尔曲线的快慢。 如题: 【问题】下面使用Animate-timing-function定义的贝塞尔曲线,哪一个是先快后慢的(A)

A. animation-timing-function :cubic-bezier(.22,1.23,.97,.89)

B. animation-timing-function :cubic-bezier(1.23,…22,97,.89)

C. animation-timing-function :cubic-bezier(1.23,.97,.89,.22)

D. animation-timing-function :cubic-bezier(.22,.97,.89,1.23)

解析: A.k1=5.59,k2=0.91 先快后慢 B.k1=0.17,k2=0.009 慢 C.k1=0.78,k2=0.24 慢 D.k1=0.22,k2=1.38 先慢后快

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

【知识点:Animate-timing-function定义的贝塞尔曲线】

①transition-timing-function属性

transition-timing-function属性指定切换效果的速度。

此属性允许一个过渡效果,以改变其持续时间的速度。

语法:transition-timing-function: cubic-bezier(n,n,n,n);

https://www.runoob.com/cssref/css3-pr-transition-timing-function.html

②cubic-bezier() 函数

cubic-bezier() 函数定义了一个贝塞尔曲线(Cubic Bezier)。

贝塞尔曲线由四个点 P0,P1,P2 和 P3 定义。P0 和 P3 是曲线的起点和终点。P0是(0,0)并且表示初始时间和初始状态,P3是(1,1)并且表示最终时间和最终状态。

在这里插入图片描述
在这里插入图片描述

我们需要关注的是 P1 和 P2 两点的取值,而其中 X 轴的取值范围是 0 到 1,当取值超出范围时 cubic-bezier 将失效;Y 轴的取值没有规定,当然也毋须过大。

最直接的理解是,将以一条直线放在范围只有 1 的坐标轴中,并从中间拿出两个点来拉扯(X 轴的取值区间是 [0, 1],Y 轴任意),最后形成的曲线就是动画的速度曲线。

cubic-bezier() 可用于 animation-timing-function 和 transition-timing-function 属性。

语法:cubic-bezier(x1,y1,x2,y2)

https://www.runoob.com/cssref/func-cubic-bezier.html

③贝塞尔曲线的快慢

cubic-bezier(x1,y1,x2,y2)

快慢由斜率k决定,k1=y1/x1,k2=y2/x2,k>1 则为快,k<1则为慢

图解 https://cubic-bezier.com/#.17,.67,.83,.67

在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-01-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • ①transition-timing-function属性
  • ②cubic-bezier() 函数
  • ③贝塞尔曲线的快慢
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档