小程序倒计时

Posted Faded露露

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小程序倒计时相关的知识,希望对你有一定的参考价值。

1、一般我们说的显示秒杀都是指的单条数据,循环我没做。

效果:

技术分享图片

2、wxml代码:

<p> 
  <block wx:if="{{total_micro_second<=0}}">
剩余时间:已经截止
</block>
<block wx:if="{{clock!=‘已经截止‘}}">
剩余时间:{{clock}}
</block>
</p>

 

3、.js文件代码:


function countdown(that) {
  var EndTime = that.data.end_time || [];
  var NowTime = new Date().getTime();
  var total_micro_second = EndTime - NowTime || [];   //单位毫秒
  if (total_micro_second < 0) {
    console.log(时间初始化小于0,活动已结束状态);
    total_micro_second = 1;     //单位毫秒 ------  WHY?
  }
  console.log(剩余时间: + total_micro_second);
  // 渲染倒计时时钟
  that.setData({
    clock: dateformat(total_micro_second)   //若已结束,此处输出‘0天0小时0分钟0秒‘
  });
  if (total_micro_second <= 0) {
    that.setData({
      clock: "已经截止"
    });
    return;
  }
  setTimeout(function () {
    total_micro_second -= 1000;
    countdown(that);
  }
    , 1000)
}

// 时间格式化输出,如11天03小时25分钟19秒  每1s都会调用一次
function dateformat(micro_second) {
  // 总秒数
  var second = Math.floor(micro_second / 1000);
  // 天数
  var day = Math.floor(second / 3600 / 24);
  // 小时
  var hr = Math.floor(second / 3600 % 24);
  // 分钟
  var min = Math.floor(second / 60 % 60);
  //
  var sec = Math.floor(second % 60);
  return day + "" + hr + "小时" + min + "分钟" + sec + "";
}

Page({

  /**
   * 页面的初始数据
   */
  data: {
    id: ‘‘,
    result: [],
    end_time: ‘‘,
    clock: ‘‘
  },/**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    var that = this;
    wx.request({
      url: https://m.******.com/index.php/Home/Xiaoxxf/activity_detail?a_id= + options.id,//不含富文本html
      data: {},
      method: GET, // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
      header: {
        Content-Type: application/json
      },
      success: function (res) {
        that.setData({
          common: res.data,   //一维数组,全部数据
          end_time: res.data.end_time    //项目截止时间,时间戳,单位毫秒
        })
        console.log(that.data.common);
        console.log(结束时间: + that.data.end_time);
      },
      fail: function (res) { },
      complete: function (res) { },
    })
    //调用上面定义的递归函数,一秒一刷新时间
    countdown(that)
  }
})

 








以上是关于小程序倒计时的主要内容,如果未能解决你的问题,请参考以下文章

python使用上下文对代码片段进行计时,非装饰器

微信小程序添加闹钟代码

微信小程序代码片段分享

小程序各种功能代码片段整理---持续更新

微信小程序倒计时组件开发

完整且易读的微信小程序的注册页面(包含倒计时验证码获取用户信息)