微信小程序开发animation心跳动画效果


Posted in Javascript onAugust 16, 2017

本文实例为大家分享了微信小程序开发animation心跳动画,供大家参考,具体内容如下

1、微信小程序开发animation心跳动画

wxml文件中:

<view class="bottomViewItem"> 
  <view class="bottomMiddleHeaderView" bindtap="voteClick" data-id="value"> 
   <view class="bottomMiddleHeaderItem" animation="{{animationMiddleHeaderItem}}"> 
   <!-- 心跳 --> 
   <view class="bottomMiddleHeaderItemSubView"> 
    <image src="/images/detail_vote_heart.png" style="width:32rpx; height:32rpx;" animation="{{animationMiddleHeaderItem}}"></image> 
   </view> 
   <!-- 投票文字 --> 
   <view class="bottomMiddleHeaderItemSubView">投票</view> 
   </view> 
  </view> 
 </view>

js文件中:

// 页面渲染完成 
 onReady: function () { 
  var circleCount = 0; 
  // 心跳的外框动画 
  this.animationMiddleHeaderItem = wx.createAnimation({ 
  duration:1000, // 以毫秒为单位 
  /** 
  * http://cubic-bezier.com/#0,0,.58,1 
  * linear 动画一直较为均匀 
  * ease 从匀速到加速在到匀速 
  * ease-in 缓慢到匀速 
  * ease-in-out 从缓慢到匀速再到缓慢 
  * 
  * http://www.tuicool.com/articles/neqMVr 
  * step-start 动画一开始就跳到 100% 直到动画持续时间结束 一闪而过 
  * step-end 保持 0% 的样式直到动画持续时间结束  一闪而过 
  */ 
  timingFunction: 'linear', 
  delay: 100, 
  transformOrigin: '50% 50%', 
  success: function (res) { 
  } 
  }); 
  setInterval(function() { 
  if (circleCount % 2 == 0) { 
   this.animationMiddleHeaderItem.scale(1.15).step(); 
  } else { 
   this.animationMiddleHeaderItem.scale(1.0).step(); 
  } 
  this.setData({ 
   animationMiddleHeaderItem: this.animationMiddleHeaderItem.export() 
  }); 
  circleCount++; 
  if (circleCount == 1000) { 
   circleCount = 0; 
  } 
  }.bind(this), 1000); 
 },

2、微信显示倒计时

wxml文件中:

<!--倒计时 --> 
 <view class="countDownTimeView countDownAllView" > 
 <view class="voteText countDownTimeText">{{countDownDay}}天</view> 
 <view class="voteText countDownTimeText">{{countDownHour}}时</view> 
 <view class="voteText countDownTimeText">{{countDownMinute}}分</view> 
 <view class="voteText countDownTimeText">{{countDownSecond}}秒</view> 
 </view>

js文件中:

Page( { 
 data: { 
 windowHeight: 654, 
 maxtime: "", 
 isHiddenLoading: true, 
 isHiddenToast: true, 
 dataList: {}, 
 countDownDay: 0, 
 countDownHour: 0, 
 countDownMinute: 0, 
 countDownSecond: 0, 
 }, 
 //事件处理函数 
 bindViewTap: function() { 
 wx.navigateTo( { 
  url: '../logs/logs' 
 }) 
 }, 
 onLoad: function() { 
 this.setData( { 
  windowHeight: wx.getStorageSync( 'windowHeight' ) 
 }); 
 }, 
 // 页面渲染完成后 调用 
 onReady: function () { 
 var totalSecond = 1505540080 - Date.parse(new Date())/1000; 
 var interval = setInterval(function () { 
  // 秒数 
  var second = totalSecond; 
  // 天数位 
  var day = Math.floor(second / 3600 / 24); 
  var dayStr = day.toString(); 
  if (dayStr.length == 1) dayStr = '0' + dayStr; 
  // 小时位 
  var hr = Math.floor((second - day * 3600 * 24) / 3600); 
  var hrStr = hr.toString(); 
  if (hrStr.length == 1) hrStr = '0' + hrStr; 
  // 分钟位 
  var min = Math.floor((second - day * 3600 *24 - hr * 3600) / 60); 
  var minStr = min.toString(); 
  if (minStr.length == 1) minStr = '0' + minStr; 
  // 秒位 
  var sec = second - day * 3600 * 24 - hr * 3600 - min*60; 
  var secStr = sec.toString(); 
  if (secStr.length == 1) secStr = '0' + secStr; 
  this.setData({ 
  countDownDay: dayStr, 
  countDownHour: hrStr, 
  countDownMinute: minStr, 
  countDownSecond: secStr, 
  }); 
  totalSecond--; 
  if (totalSecond < 0) { 
  clearInterval(interval); 
  wx.showToast({ 
   title: '活动已结束', 
  }); 
  this.setData({ 
   countDownDay: '00', 
   countDownHour: '00', 
   countDownMinute: '00', 
   countDownSecond: '00', 
  }); 
  } 
 }.bind(this), 1000); 
 }, 
 //cell事件处理函数 
 bindCellViewTap: function (e) { 
 var id = e.currentTarget.dataset.id; 
 wx.navigateTo({ 
  url: '../babyDetail/babyDetail?id=' + id 
 }); 
 } 
})

效果图:

微信小程序开发animation心跳动画效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Extjs4中的分页应用结合前后台
Dec 13 Javascript
javascript实现的弹出层背景置灰-模拟(easyui dialog)
Dec 27 Javascript
JS实现的不规则TAB选项卡效果代码
Sep 18 Javascript
深入浅析Node.js 事件循环
Dec 20 Javascript
Angular ng-repeat 对象和数组遍历实例
Sep 14 Javascript
JS两种类型的表单提交方法实例分析
Nov 28 Javascript
jquery实现多次上传同一张图片
Jan 09 Javascript
详解使用create-react-app快速构建React开发环境
May 16 Javascript
JavaScript使用math.js进行精确计算操作示例
Jun 19 Javascript
原生javascript制作的拼图游戏实现方法详解
Feb 23 Javascript
vue实现页面切换滑动效果
Jun 29 Javascript
在Vue中使用CSS3实现内容无缝滚动的示例代码
Nov 27 Vue.js
全选复选框JavaScript编写小结(附代码)
Aug 16 #Javascript
微信小程序自定义模态对话框实例详解
Aug 16 #Javascript
浅析webpack 如何优雅的使用tree-shaking(摇树优化)
Aug 16 #Javascript
JavaScript实现三级联动菜单效果
Aug 16 #Javascript
ionic3 懒加载
Aug 16 #Javascript
JavaScript仿微信(电话)联系人列表滑动字母索引实例讲解(推荐)
Aug 16 #Javascript
理解 Node.js 事件驱动机制的原理
Aug 16 #Javascript
You might like
一个用于mysql的数据库抽象层函数库
2006/10/09 PHP
关于页面优化和伪静态
2009/10/11 PHP
php读取大文件示例分享(文件操作类)
2014/04/13 PHP
smarty模板引擎从php中获取数据的方法
2015/01/22 PHP
php里array_work用法实例分析
2015/07/13 PHP
ThinkPHP开发框架函数详解:C方法
2015/08/14 PHP
JQuery操作三大控件(下拉,单选,复选)的方法
2013/08/06 Javascript
javascript与css3动画结合使用小结
2015/03/11 Javascript
Jquery Mobile 自定义按钮图标
2015/11/18 Javascript
AngularJS过滤器filter用法总结
2016/12/13 Javascript
canvas绘制多边形
2017/02/24 Javascript
对象不支持indexOf属性或方法的解决方法(必看)
2017/05/28 Javascript
javascript中mouseenter与mouseover的异同
2017/06/06 Javascript
详解vue前后台数据交互vue-resource文档
2017/07/19 Javascript
详解vue 组件之间使用eventbus传值
2017/10/25 Javascript
JS设计模式之命令模式概念与用法分析
2018/02/06 Javascript
原生js检测页面加载完毕的实例
2018/09/11 Javascript
详解在网页上通过JS实现文本的语音朗读
2019/03/28 Javascript
基于原生JS封装的Modal对话框插件的示例代码
2020/09/09 Javascript
django rest framework之请求与响应(详解)
2017/11/06 Python
Python使用requests发送POST请求实例代码
2018/01/25 Python
Django框架教程之中间件MiddleWare浅析
2019/12/29 Python
pytorch 使用加载训练好的模型做inference
2020/02/20 Python
Pytorch实现将模型的所有参数的梯度清0
2020/06/24 Python
tensorflow下的图片标准化函数per_image_standardization用法
2020/06/30 Python
百丽国际旗下购物网站:优购
2017/02/28 全球购物
巴西手表购物网站:eclock
2019/03/19 全球购物
戛纳奢侈品商店:Jacques Loup法国
2019/11/04 全球购物
乌克兰品牌化妆品和香水在线商店:Bomond
2020/01/14 全球购物
blueseventy官网:铁人三项和比赛泳衣
2021/02/06 全球购物
教育学习自我评价
2014/02/03 职场文书
益达广告词
2014/03/14 职场文书
合同协议书格式
2014/04/18 职场文书
简历自我评价优缺点
2015/03/11 职场文书
2015年党建工作汇报材料
2015/06/25 职场文书
Python 数据科学 Matplotlib图库详解
2021/07/07 Python