E企盈营销工具技术服务商 热线:4006-838-530

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

E企盈直播平台营销卖货系统

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

赞(0) 打赏
未经允许不得转载:E企盈小程序开发-热线:4006-838-530 » 小程序列表多个批量倒计时
分享到: 更多 (0)
E企盈小程序直播营销卖货系统
E企盈直播平台营销卖货系统

评论 抢沙发

E企盈小程序开发

联系我们联系我们

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏