Skip to content

NPM酷库:Anime.js 简介

Anime.js 是一个轻量级的 Javascript 动效库,简单但功能强大。 它基于 CSS 属性,SVG,DOM属性和 Javascript 对象 工作。

Anime.js (/ˈæn.ə.meɪ/) is a lightweight JavaScript animation library with a simple, yet powerful API. It works with CSS properties, SVG, DOM attributes and JavaScript Objects.

传统上,我们通过逐渐修改一个元素的造型来制作动画。这样的动作在 JavaScript 中是可以实现的,但即使是最简单的动画,开发起来也是很困难和费时的。

Anime.js 通过提供各种工具使动画更容易。它提供了调节时间和用户输入的功能,并支持在同一个对象上同时运行许多动画。

大多数流行的浏览器也支持Anime.js。

Anime.js 的安装

  • 你可以从下面提供的链接中下载anime.min.js文件后直接使用

https://github.com/juliangarnier/anime/archive/master.zip

html
<script src="./folder/subFolder/anime.min.js"></script>
  • 你可以通过搜索 “anime.js CDN “找到这个链接,并将其粘贴到你的脚本标签中。
html
<script src="https://cdnjs.cloudflare.com/ajax/libs/animejs/3.2.0/anime.min.js"></script>

Anime.js的基本语法

我们已经看到了如何安装anime.js和它的基础知识,现在让我们来看看anime.js的语法 —

js
let animation = anime ({
   targets,
   properties,
   property parameters,
   animation parameters,
});

在上面的语法中,我们使用Anime.js提供的anime()函数创建了一个动画,anime()函数接受一个JavaScript对象作为参数,其中包含了我们动画的属性。

现在我们来详细讨论一下Anime.js基本语法中的每一个术语–

targets

目标中包含了对我们希望制作动画的组件的引用,其形式可以是HTML标签、类或id元素、任何CSS选择器、单个DOM节点或DOM节点数组;用JavaScript创建的对象,至少有一个数字属性和由前三个值中的任何一个组成的数组。

properties

在提到目标之后,我们会提到我们想要动画化的属性。属性可以包括可以被动画化的CSS、JS和SVG属性。

属性参数

属性参数包括在很大程度上影响动画的时间的方面。这个属性参数涵盖了几个特性参数,包括持续时间、延迟、结束-延迟、缓和、圆形等等。

动画参数

动画的前后动作是由动画参数控制的。这包括与动画有关的选项,包括方向、循环和自动播放。

控制

为了使动画具有互动性,Anime.js进一步提供了控制工具。下面是这些技术的一些例子,开始、暂停、反转和重新开始。

示例1

在这个例子中,我们将创建一些具有特定宽度和高度尺寸的div元素。使用一些CSS,我们将添加一个特定的背景颜色。在JavaScript部分,我们首先要在anime函数中添加所有需要的东西,然后传递具有这些属性的对象。

覆盖所有内容后,现在我们的主要目标是在所需元素上制作动画,也就是这里的div块。在这种情况下,我们将从初始位置向X轴方向使用translateX。

html
<html>
<head>
   <script src= "https://cdnjs.cloudflare.com/ajax/libs/animejs/3.2.0/anime.min.js"></script> 
</head>
<body>
   <h2>
      Introduction of Anime.Js   </h2>
   <div style="background: green;
      height: 30px;
      width: 50px;">
   </div>
   <script>
      let animation = anime({
         targets: "div",
         translateX: 150,
         easing: "linear",
         direction: "alternate",
         height: "100px",
         width: "100px",
         duration: 2300,
         loop: true,
      });
   </script>
</body>
</html>

在上面的代码中,首先,我们定义了HTML代码的主要结构,然后我们使用代码头部的’src’标签将anime.js库添加到我们的代码。在正文中,我们首先定义了要实现动画的div元素。然后在脚本标签中,我们定义了我们需要的动画类型,即给定的绿色块从它的位置到另一个位置的运动,并在一定的时间内改变该块的大小。

示例2

在前面的例子中,我们定义了一个盒子,并通过动画来增加它的高度和宽度,现在我们要改变它的高度和宽度,但是要增加宽度和减少高度。

html
<html>
<head>
   <script src= "https://cdnjs.cloudflare.com/ajax/libs/animejs/3.2.0/anime.min.js"></script>
</head>
<body>
   <h2>
      Increasing the size of width and decreasing the size of height   </h2>
   <div style="background: green;
      height: 100px;
      width: 10px;">
   </div>
   <script>
      let animation = anime({
         targets: "div",
         translateX: 150,
         easing: "linear",
         direction: "alternate",
         height: "10px",
         width: "100px",
      });
   </script>
</body>
</html>

在上面的代码中,首先,我们定义了HTML代码的主要结构,然后我们使用代码头部的’src’标签将anime.js库添加到我们的代码。在正文中,我们首先定义了要实现动画的div元素。然后在脚本标签中,我们定义了我们需要的动画类型,即给定的绿色块从它的位置到另一个位置的运动,并在一定的时间内改变块的大小,即减少高度和增加宽度的大小。

示例3

在这个例子中,我们将使用anime.js库将一个长方形的盒子变成一个圆形的动画。我们将设置变化的持续时间为3000秒,并在一个循环中运行。让我们看看代码

html
<html>
<head>
   <script src= "https://cdnjs.cloudflare.com/ajax/libs/animejs/3.2.0/anime.min.js"></script>
</head>
<body>
   <center>
      <h1 style="color: red;">More Animation by anime.js</h1>
      <b>
         Here we will do animation on the border      </b>
      <div style="background: blue;
         width: 100px;
         height: 100px;
         padding-top: 10px; ">
      </div>
   </center>
   <script>
      let animation = anime({
         targets: "div",
         easing: "easeInOutQuad",
         loop: true,
         duration: 3000,
         backgroundColor: "yellow",
         borderRadius: "110px",
      });
   </script>
</body>
</html>

在上面的代码中,首先,我们定义了HTML代码的主要结构,然后我们使用代码头部的’src’标签将anime.js库添加到我们的代码。在正文中,我们首先定义了要实现动画的div元素。然后在脚本标签中,我们定义了我们所需要的动画类型,即在三秒或3000毫秒内将给定的蓝色盒子移动到一个蓝色圆圈。

总结

在本教程中,我们通过实例详细讨论了Anime.js。Anime.js是一个轻量级的JavaScript库,有一个简单有效的API。它的功能包括JavaScript对象、CSS和DOM元素,而且Anime.js很容易使用。传统上,我们通过逐渐修改一个元素的造型来制作动画。这样的动作用JavaScript就可以实现,但即使是最简单的动画,开发起来也很困难,而且很费时间。

参考链接

https://animejs.com/

https://geek-docs.com/javascript/javascript-tutorials/t_introduction-to-anime-js.html