欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

小程序实现列表多个批量倒计时

程序员文章站 2023-12-06 00:02:10
最近在写一个列表功能,列表中有倒计时的效果,网上没有可用的素材,以下是本人自己写的,如有问题,希望大家指出。 先来看看基本的效果 小程序中列表倒计时,类似活动倒...

最近在写一个列表功能,列表中有倒计时的效果,网上没有可用的素材,以下是本人自己写的,如有问题,希望大家指出。

先来看看基本的效果

小程序实现列表多个批量倒计时

小程序中列表倒计时,类似活动倒计时列表,列表中有多个倒计时效果,且不冲突

先把时间打印出来,放在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不支持这种操作。

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