小程序列表多个批量倒计时
- 小程序列表多个批量倒计时 推荐度:
- 相关推荐
小程序列表多个批量倒计时
修复更新-----2019-11-22
订单列表中倒计时-wxml
<view wx:for="{{wearList.datetime}}" wx:for-item="item" wx:key="id"><view class='dates'>{{item.difftime}}</view>
</view>
在封装倒计时之前,需要设置一个存放倒计时的容器
data: {timeArr1: [], // 存放倒计时},
倒计时封装,getFormat2方法是封装解析时间戳的方法,在此就不做展示了
setCountDown () {let time = 100;let that = this;that.data.timeArr1 = setInterval(function(){for (let i=0;i<that.data.listdata.length;i++) {let nowtimes = 30*60*1000-(new Date().getTime()-that.data.listdata[i].createDate);if (nowtimes==0 ) {console.log('时间到了')that.getlistdata(that.data.pageNum)// that.data.listdata[i].createDate = 0;}let formatTimes = getFormat2(nowtimes);// that.data.listdata[i].createDate -= time;that.data.listdata[i].countDown = `${formatTimes.hh}:${formatTimes.mm}:${formatTimes.ss}`;}that.setData({listdata: that.data.listdata});},time)},
在请求订单列表之前,需要先清除计时器,最好放在onShow里边,同样销毁页面隐藏页面的方法里最好也清除计算器,否则进入订单详情再返回的时候,倒计时就会出现紊乱的情况
clearInterval(that.data.timeArr1)
请求订单列表时,导入上边封装好的倒计时方法that.setCountDown()
原文-----2017-12-22 11:07:41
最近在写一个列表功能,列表中有倒计时的效果,网上没有可用的素材,以下是本人自己写的,如有问题,希望大家指出。
先来看看基本的效果
小程序中列表倒计时,类似活动倒计时列表,列表中有多个倒计时效果,且不冲突
先把时间打印出来,放在data中,然后在写计时器;如果先写计时器,然后把打印出来的时间放在data就会报错,setData不支持这种操作。
数据文件(dates.js,返回的时间数据是剩余时间)
var dates=[{dat:324235235},{dat:7200000},{dat:675875754}
]module.exports = {datetime: dates
}
wxml文件(a.wxml)
<view wx:for="{{wearList.datetime}}" wx:for-item="item" wx:key="id"><view class='dates'>{{item.difftime}}</view>
</view>
js文件(a.js)
var dates=require('../utils/dates.js');//数据文件Page({data:{},onShow(a){// console.log(dates.datetime)//数据let that=this;let len=dates.datetime.length;//时间数据长度function nowTime() {//时间函数// console.log(a)for (var i = 0; i < len; i++) {var intDiff = dates.datetime[i].dat;//获取数据中的时间戳// console.log(intDiff)var day=0, hour=0, minute=0, second=0; if(intDiff > 0){//转换时间day = Math.floor(intDiff / (60 * 60 * 24));hour = Math.floor(intDiff / (60 * 60)) - (day * 24);minute = Math.floor(intDiff / 60) - (day * 24 * 60) - (hour * 60);second = Math.floor(intDiff) - (day * 24 * 60 * 60) - (hour * 60 * 60) - (minute * 60);if(hour <=9) hour = '0' + hour;if (minute <= 9) minute = '0' + minute;if (second <= 9) second = '0' + second;dates.datetime[i].dat--;var str=hour+':'+minute+':'+ second // console.log(str) }else{var str = "已结束!";clearInterval(timer); }// console.log(str);dates.datetime[i].difftime = str;//在数据中添加difftime参数名,把时间放进去}that.setData({wearList: dates})// console.log(that)}nowTime();var timer = setInterval(nowTime, 1000);}
})
小程序中列表倒计时,类似活动倒计时列表,列表中有多个倒计时效果,且不冲突
先把时间打印出来,放在data中,然后在写计时器;如果先写计时器,然后把打印出来的时间放在data就会报错,setData不支持这种操作。
最新文章
- 卷积神经网络使用到的公式
- matlab stats里的f值,MATLAB 回归分析regress,nlinfit,stepwise函数
- rowid详细介绍
- 什么是 Null Pointer Exceptions (java.lang.NullPointerException) ,是什么原因造成的?
- 概率漫谈 转自 林达华
- SNMP的工作原理
- React:Component组件
- CaptureScreenshot捕捉画面截图截屏
- Jmeter——BeanShell PreProcessor的用法
- Element
- SAR成像系列:【11】干涉合成孔径雷达(干涉SAR,Interferometric SAR,InSAR)
- 快速组合排列算法
- 前后端异地、接口如何联调呢
- 基于React、Typescript和Solidity的NFT完整教程
- Https单向认证和双向认证 认识和区别
- python try:except: 捕获到的异常输出到 log文件
- PHP使用header实现文件下载功能