内置缓动

jswaapi 两种 `animate()` 函数都包含一组内置缓动函数,这些函数可以直接在 `ease` 参数中通过名称指定。

animate(target, { x: 100, ease: 'outQuad' });
animate(target, { x: 100, ease: 'outExpo' });
animate(target, { x: 100, ease: 'outElastic(.8, 1.2)' });

所有内置缓动函数也可以通过导入的 eases 对象访问。

import { eases } from 'animejs';

eases.outQuad;
eases.outExpo;
eases.outElastic(.8, 1.2);

内置缓动函数列表

类型 参数 变体 (点击链接在编辑器中打开)
线性 -- 'linear'
幂函数 幂 = 1.675 'in', 'out', 'inOut', 'outIn'
二次函数 -- 'inQuad', 'outQuad', 'inOutQuad', 'outInQuad'
三次函数 -- 'inCubic', 'outCubic', 'inOutCubic', 'outInCubic'
四次函数 -- 'inQuart', 'outQuart', 'inOutQuart', 'outInQuart'
五次函数 -- 'inQuint', 'outQuint', 'inOutQuint', 'outInQuint'
正弦 -- 'inSine', 'outSine', 'inOutSine', 'outInSine'
指数函数 -- 'inExpo', 'outExpo', 'inOutExpo', 'outInExpo'
圆形函数 -- 'inCirc', 'outCirc', 'inOutCirc', 'outInCirc'
弹性回弹 -- 'inBounce', 'outBounce', 'inOutBounce', 'outInBounce'
回退 超出量 = 1.70158 'inBack', 'outBack', 'inOutBack', 'outInBack'
弹性 振幅 = 1,
周期 = .3
'inElastic', 'outElastic', 'inOutElastic', 'outInElastic'

内置缓动代码示例

import { animate, waapi } from 'animejs';

animate('.row:nth-child(1) .square', {
  x: '17rem',
  rotate: 360,
  ease: 'inOut',
});

animate('.row:nth-child(2) .square', {
  x: '17rem',
  rotate: 360,
  ease: 'inOut(3)',
});

waapi.animate('.row:nth-child(3) .square', {
  x: '17rem',
  rotate: 360,
  ease: 'inOutExpo',
});
<div class="medium row">
  <div class="square"></div>
  <div class="padded label">'inOut'</div>
</div>
<div class="medium row">
  <div class="square"></div>
  <div class="padded label">'inOut(3)'</div>
</div>
<div class="medium row">
  <div class="square"></div>
  <div class="padded label">'inOutExpo'</div>
</div>