微信小程序动画(Animation)的实现及执行步骤

 更新时间:2018年10月28日 09:29:15   作者:FlyLolo  
这篇文章主要介绍了微信小程序动画(Animation) 的实现及执行步骤,需要的朋友可以参考下

简单总结一下微信动画的实现及执行步骤。

一、实现方式

官方文档是这样说的:①创建一个动画实例 animation。②调用实例的方法来描述动画。③最后通过动画实例的 export 方法导出动画数据传递给组件的 animation 属性。

因为小程序是数据驱动的,给这句话加上数字标注分为三步:

前两步是定义一个动画并设置都要干什么,然后把这个设置好的“规则”扔给界面上的某个元素,让它按照这个规则执行。

当然如果有多个元素的animation="{{ani}}",也都会执行这个动画规则。

二、用例子说话

新建一个小程序,把没用的删掉修改一下,做个简单例子,上图

代码如下:

index.wxml,一个helloworld,一个按钮

<view class="container">
 <view class="usermotto" animation="{{ani}}">
  <text class="user-motto">{{motto}}</text>
 </view>
 <button bindtap='start'>动画</button>
</view>

index.wxss, 为了看着方便加了个边框

.usermotto {
 margin-top: 100px;
 border: solid;
}

index.js

Page({
 data: {
  motto: 'Hello World',
 },
 start:function(){
  var animation = wx.createAnimation({
   duration: 4000,
   timingFunction: 'ease',
   delay: 1000
  });
  animation.opacity(0.2).translate(100, -100).step()
  this.setData({
   ani: animation.export()
  })
 }
})

 三、相关参数及方法

简单介绍一下例子中的几个参数和方法(其他的详见官方文档):

      duration: 动画持续多少毫秒
      timingFunction: “运动”的方式,例子中的 'ease'代表动画以低速开始,然后加快,在结束前变慢 
      delay: 多久后动画开始运行

      opacity(0.2) 慢慢变透明

      translate(100, -100) 向X轴移动100的同时向Y轴移动-100

      step(): 一组动画完成,例如想让上例中的HelloWorld向右上方移动并变透明后,再次向左移动50可以继续写 animation.translateX( -50).step() , 作用就是向右上方移动和变透明是同时进行, 这两种变化完成之后才会进行向左运行的一步。

例子:Github

总结

以上所述是小编给大家介绍的微信小程序动画(Animation)的实现及执行步骤,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

相关文章

  • 跟我学习javascript的prototype,getPrototypeOf和__proto__

    跟我学习javascript的prototype,getPrototypeOf和__proto__

    跟我学习javascript的prototype,getPrototypeOf和__proto__,深入学习了三个用来访问prototype的方法,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • 前端传递参数时form-data和json的区别详解

    前端传递参数时form-data和json的区别详解

    前端可以通FormData对象实现表单形式提交数据,下面这篇文章主要给大家介绍了关于前端传递参数时form-data和json区别的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • 解决layui富文本编辑器图片上传无法回显的问题

    解决layui富文本编辑器图片上传无法回显的问题

    今天小编就为大家分享一篇解决layui富文本编辑器图片上传无法回显的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09
  • axios如何利用promise无痛刷新token的实现方法

    axios如何利用promise无痛刷新token的实现方法

    这篇文章主要介绍了axios如何利用promise无痛刷新token的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • 关于Vue中postcss-pxtorem的使用详解

    关于Vue中postcss-pxtorem的使用详解

    在Web开发领域,响应式设计已经成为一个不可或缺的趋势,PostCSS插件——postcss-pxtorem的出现为我们提供了一种更加智能和高效的解决方案,本文将深入探讨postcss-pxtorem的使用,包括其背后的原理、配置选项、实际应用中的注意事项等方面,需要的朋友可以参考下
    2023-12-12
  • JavaScript中的闭包原理分析

    JavaScript中的闭包原理分析

    一看到闭包这个词,我就会想起线性代数中的封闭空间,也就是说,这个空间中的所有向量,无论经过何种运算,最终结果还是会落在该空间中。那么JavaScript中会不会也是类似的概念呢?
    2010-03-03
  • DWR中各种java方法的调用

    DWR中各种java方法的调用

    DWR是一个框架,简单的说就是能够在javascript直接调用java方法,而不必去写一大堆的javascript代码。它的实现是基于ajax的,可以实现无刷新效果。不少DWR的例子,但大都只是某种方法的调用只在使用层面上介绍DWR,并不涉更多的技术与设计javascript中是如何调用的。
    2016-05-05
  • JavaScript设置名字输入不合法的实现方法

    JavaScript设置名字输入不合法的实现方法

    这篇文章主要介绍了JavaScript设置名字输入不合法的方法,需要的朋友可以参考下
    2017-05-05
  • js实现常见的工具条效果

    js实现常见的工具条效果

    本文主要介绍了js实现常见的工具条效果的实例。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-03-03
  • 学习JavaScript设计模式之模板方法模式

    学习JavaScript设计模式之模板方法模式

    这篇文章主要为大家介绍了JavaScript设计模式中的模板方法模式,对JavaScript设计模式感兴趣的小伙伴们可以参考一下
    2016-01-01

最新评论