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

 

修复更新-----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不支持这种操作。

评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值