小程序实现列表多个批量倒计时
程序员文章站
2023-11-12 11:54:04
最近在写一个列表功能,列表中有倒计时的效果,网上没有可用的素材,以下是本人自己写的,如有问题,希望大家指出。
先来看看基本的效果
小程序中列表倒计时,类似活动倒...
最近在写一个列表功能,列表中有倒计时的效果,网上没有可用的素材,以下是本人自己写的,如有问题,希望大家指出。
先来看看基本的效果
小程序中列表倒计时,类似活动倒计时列表,列表中有多个倒计时效果,且不冲突
先把时间打印出来,放在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不支持这种操作。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 论坛账号被封了怎么办?怎么解决?
下一篇: 小米小盒子正式发布 售价199元