ANIJS:CSS动画的声明性处理库
在本教程中,我们将看到Anijs的全部内容以及如何使用它来创建一些很酷的动画效果。
>库在html5数据属性中使用一个自定义属性,称为data-anijs来创建动画的声明语句。例如,代码`
`表示如果输入字段焦点,它将对锚标记元素进行“ Wobble”动画。- >库还提供了使用“之前”关键字在动画之前和之后调用功能的功能。这可以用于控制动画的流程,例如在运行动画之前验证表单条目,或者在运行动画之前显示和隐藏不同的屏幕。
- 在上面的代码中,声明语法说: 如果专注于焦点,请对锚标记元素进行摇摆。
- >
在本教程的过程中,我们将使用Anijs创建一个动画来创建一个应用程序。该应用将是一个简单的用户注册和登录应用程序,它将使用ANIJS包括一些动画。本教程的主要重点是我们如何使用Anijs在Web应用中工作。
。开始,下载anijs并将其包含在您的页面中,或引用CDN版本。
<span><span><span><input</span> id<span>="txtName"</span> type<span>="text"</span> data-anijs<span>="if: focus, do: wobble, to: a"</span>></span></span>
创建登录屏幕
首先,我们将创建一个屏幕供用户登录。这是html:到目前为止,我们拥有的只是一个静态登录页面。有了一些CSS,看起来像这样:
>请参阅codepen上的sitepoint(@sitepoint)的pen anijs教程,
上的静态登录屏幕(@sitepoint)我们已经创建了屏幕,现在我们需要验证登录过程。为了附加动画效果,我们使用特定元素上的数据anijs属性。我们使用称为data-anijs的自定义属性使用HTML5数据属性编写声明语句。让我们将此属性添加到签名按钮中,如下所示:
><span><span><span><input</span> id<span>="txtName"</span> type<span>="text"</span> data-anijs<span>="if: focus, do: wobble, to: a"</span>></span></span>
单击“登录”按钮时,使用类别.login_screen对元素进行铰链动画。因此,当我们单击按钮时,铰链动画会生效,正如您通过单击下面的演示中的签名按钮所看到的:
请参阅pen anijs演示,在codepen上通过sitepoint(@sitepoint)登录失败。在上述演示中,当按钮被单击时,无论有效还是无效的登录,动画都可以使用。这并不是我们想要的,所以让我们修改现有代码以仅在无效的登录中进行动画。
为了检查登录是否有效,我们需要在动画之前调用validation函数。为此,我们将使用之前的关键字。在ANIJS文档中可以找到与调用动画之前和之后的函数有关的详细文档。我们将通过事件对象传递到触发动画以及动画context。
>我们还将修改signin按钮的数据属性以包括之前的动画函数,如下所示: >现在,只有在电子邮件或密码字段为空的情况下,动画才会发生。使用AnimationContext.run()命令在上方的JavaScript代码块中运行动画。如果输入了电子邮件和密码,则将显示“处理……”消息。 >
>: >上面的代码单击注册链接时,在具有reg_screen类别的元素上进行滚动动画(这是我们的寄存器屏幕)。但这是行不通的,因为寄存器屏幕被隐藏了。
这是一个带有我们新添加的代码的演示: >现在可以使寄存器屏幕可见,我们还需要将寄存器屏幕中的登录链接连接到原始登录屏幕,类似于我们刚刚为寄存器屏幕所做的操作。这是函数:
>
通常,我们通常会在变量中缓存许多这些对象,而不是重复对它们的引用。我们只是为这个简单的示例而这样做。>
>
这是我们的最终演示:
什么是Anijs,它如何工作? > >使用anijs创建动画涉及添加data-anijs属性HTML元素并定义动画参数。 Data-Anijs属性使用的简单语法指定事件,动画元素,应用动画和回调函数。您还可以使用ANIJS助手函数来控制动画流。 anijs anijs支持广泛的CSS动画。您可以创建简单的动画,例如淡出和幻灯片,以及涉及转换和过渡的更复杂的动画。 ANIJS还支持动画链,使您可以创建以特定顺序执行的动画序列。 > ><span><span><span><script</span> src<span>="http://cdn.jsdelivr.net/anijs/0.4.0/anijs-min.js"</span>></span><span><span></script</span>></span></span>
<span><span><span><link</span> rel<span>="stylesheet"</span>
</span></span><span> <span>href<span>="http://cdn.jsdelivr.net/animatecss/3.1.0/animate.css"</span>></span></span>
<span><span><span><input</span> id<span>="txtName"</span> type<span>="text"</span> data-anijs<span>="if: focus, do: wobble, to: a"</span>></span></span>
<span><span><span><script</span> src<span>="http://cdn.jsdelivr.net/anijs/0.4.0/anijs-min.js"</span>></span><span><span></script</span>></span></span>
<span><span><span><link</span> rel<span>="stylesheet"</span>
</span></span><span> <span>href<span>="http://cdn.jsdelivr.net/animatecss/3.1.0/animate.css"</span>></span></span>
<span><span><span><div</span> class<span>="container"</span>></span>
</span>
<span><span><span><div</span> id<span>="divLogin"</span> class<span>="login_screen"</span>></span>
</span> <span><span><span><h2</span> id<span>="spnLogin"</span>></span>Sign In<span><span></h2</span>></span>
</span> <span><span><span><input</span> id<span>="txtLoginId"</span> type<span>="text"</span> placeholder<span>="Email Id"</span> /></span>
</span> <span><span><span><input</span> id<span>="txtLoginPass"</span> type<span>="password"</span> placeholder<span>="Password"</span> /></span>
</span> <span><span><span><a</span> href<span>="#"</span> class<span>="btn"</span>></span>
</span> SignIn
<span><span><span></a</span>></span>
</span> <span><span><span><a</span> href<span>="#"</span> class<span>="signup-link"</span>></span>Register?<span><span></a</span>></span>
</span> <span><span><span></div</span>></span><!-- .login-screen -->
</span>
<span><span><span></div</span>></span><!-- .container --></span>
<span><span><span><a</span> href<span>="#"</span>
</span></span><span> <span>class<span>="btn"</span>
</span></span><span> <span>data-anijs<span>="if: click, do: hinge animated, to: .login_screen"</span>></span>
</span> SignIn
<span><span><span></a</span>></span></span>
<span>var animationHelper = AniJS.getHelper(),
</span> spnLogin <span>= document.getElementById('spnLogin');
</span>
animationHelper<span>.validateLogin = function (e<span>, animationContext</span>) {
</span> <span>var email = document.getElementById('txtLoginId').value;
</span> <span>var pass = document.getElementById('txtLoginPass').value;
</span> <span>if (email && pass) {
</span> spnLogin<span>.innerHTML = 'Processing...';
</span> <span>} else {
</span> spnLogin<span>.innerHTML = 'Fill Required fields.';
</span> animationContext<span>.run();
</span> <span>}
</span><span>}</span>
<span><span><span><a</span> href<span>="#"</span>
</span></span><span> <span>class<span>="btn"</span>
</span></span><span> <span>data-anijs<span>="if: click, do: hinge animated, to: .login_screen, before: validateLogin"</span>></span>
</span> SignIn
<span><span><span></a</span>></span></span>
>如何安装anijs?
安装Anijs很简单。您可以直接从GitHub存储库下载它,也可以使用NPM或Bower等软件包管理器。下载后,您只需要在HTML文件中包含ANIJS脚本即可。然后,您可以通过将data-anijs属性添加到您的html元素来开始使用anijs。>我可以使用Anijs创建哪些类型的动画?
我可以使用anijs进行响应式设计吗?
是的,可以将anijs用于响应式设计。使用ANIJS创建的动画基于CSS,这意味着它们可以缩放并适应不同的屏幕尺寸和分辨率。这使ANIJS成为创建在台式机和移动设备上都可以正常工作的动画的有用工具。如何控制Anijs中动画的时间?我可以为Anijs的发展做出贡献吗?您可以通过报告错误,建议新功能,改进文档或提交代码改进的拉请请求来做出贡献。您可以找到有关如何在Anijs GitHub页面上做出贡献的更多信息。
>
以上是ANIJS:CSS动画的声明性处理库的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

Python更适合初学者,学习曲线平缓,语法简洁;JavaScript适合前端开发,学习曲线较陡,语法灵活。1.Python语法直观,适用于数据科学和后端开发。2.JavaScript灵活,广泛用于前端和服务器端编程。

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

从C/C 转向JavaScript需要适应动态类型、垃圾回收和异步编程等特点。1)C/C 是静态类型语言,需手动管理内存,而JavaScript是动态类型,垃圾回收自动处理。2)C/C 需编译成机器码,JavaScript则为解释型语言。3)JavaScript引入闭包、原型链和Promise等概念,增强了灵活性和异步编程能力。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务
