【微信小程序】15分钟倒计时(附带天数和时钟的实现方法在文章中)

这是制作的订单支付前倒计时,如果客户在规定时间内没能 支付,则系统自动删除,这样就以便有些商品冗余,当然了,这里只有分钟和秒钟,天数和时钟我写在了最底下,最后代码的显示第七行,可以看一下,然后带入到相应的地方。

这是实现的效果,每秒钟都在onload()里面被调用,然后自动动态倒计时。

其实难度不是很大,有一些代码防止你们看不懂,我会在下面注解出来的。

首先还是wxml

html 复制代码
<view class='demo-text2'>
   <text>倒计时:{{countdown}}</text>
</view>

其次是wxss:

css 复制代码
.demo-text2 {
  font-size: 28rpx;
  color: #ff7ba8;
}

我就加了一个颜色,哈哈哈哈~,你们可以根据自己的意思加字和东西,很好加的。

最后就是最重要的js里,注释我会写在最下面的。

js 复制代码
Page({

  /**
   * 页面的初始数据
   */
  data: {
    
  },
  
  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    var that = this
    that.countDown();
  },

  //倒计时
  countDown() {
    var that = this

    var starttime = '2019/07/30 09:04:19'

    var start = new Date(starttime.replace(/-/g, "/")).getTime()
    var endTime = start + 15 * 60000

    var date = new Date(); //现在时间
    var now = date.getTime(); //现在时间戳

    var allTime = endTime - now
    var m, s;
    if (allTime > 0) {
      m = Math.floor(allTime / 1000 / 60 % 60);
      s = Math.floor(allTime / 1000 % 60);
      that.setData({
        countdown: m + ":" + s,
      })
      setTimeout(that.countDown, 1000);
    } else {
      console.log('已截止')
      that.setData({
        countdown: '00:00'
      })
    }
  },
})

首先,是开始的时间,注意,千万不要是现在时间,不然一直是15分钟,无法改变的。

如果你想要用获取的时间,把我上面的时间改成在onload()里获取的时间就好了,this.data.你的时间属性。

var starttime = '2019/07/30 09:04:19'

var start = new Date(starttime.replace(/-/g, "/")).getTime() //时间转时间戳

这里有个重点,replace(/-/g, "/") 里面的/符号是根据starttime 的日期时间的符号改变的,

如果是 "---" ,就把里面 / 改成 --- 就好了。
var endTime = start + 15 * 60000 表示之前的时间加15分钟,如果想30分钟,改一下就好了,随你们用。

第二点,如果获取到了时间就不用使用上面的时间转时间戳了。

因为后面是用时间戳计算的,如果是用时间计算,比较麻烦,建议用时间戳。

第三点,因为我这里只有分钟和秒钟,如果你需要时钟和天数的话,d代表day(天数),h代表(时钟)加入下面代码。

复制代码
  var d,h,m, s;
  d = Math.floor(allTime/ 1000 / 60 / 60 / 24);
  h = Math.floor(allTime/ 1000 / 60 / 60 % 24);
  countdown: d + ":" +  h + ":" + m + ":" + s,
  countdown: '00:00:00:00'

加在对应的位置一看就知道吧,哪里相同加哪里。

setTimeout(that.countDown, 1000);指定的毫秒数后调用函数,后面的数字是指定毫秒。

注:如果需要小时显示几天的倒计时,请勿除于24,否则会显示为当天的24小时,此代码需要改为

h = Math.floor(allTime/ 1000 / 60 / 60);

好了,这就是倒计时的所有代码了,有问题的请留言。

相关推荐
深红1 小时前
玩转小程序AR-实战篇
前端·微信小程序·webvr
00后程序员张3 小时前
HTTPS Everywhere 时代的抓包挑战,从加密流量解析到底层数据流捕获的全流程方案
网络协议·http·ios·小程序·https·uni-app·iphone
我命由我123458 小时前
微信小程序 - scroll-view 的一些要点(scroll-view 需要设置滚动方向、scroll-view 需要设置高度)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
weixin_472183549 小时前
微信小程序使用websocket
websocket·微信小程序·小程序
发财北9 小时前
线上交友APP怎么开发?
小程序
2501_9159214310 小时前
Bundle Id 创建与管理的工程化方法,一次团队多项目协作中的流程重构
服务器·ios·小程序·重构·https·uni-app·iphone
少云清10 小时前
【功能测试】4_小程序项目 _Ego微商小程序测试点分析
功能测试·小程序
说私域11 小时前
直播带货的困境与突破:基于“开源AI智能名片链动2+1模式S2B2C商城小程序”的创新研究
人工智能·小程序·开源
2501_9159090611 小时前
深度解析 iOS 内存占用,构建多工具协同的内存诊断、监控与优化体系
android·ios·小程序·https·uni-app·iphone·webview
菜鸟学Python12 小时前
零基础用AI编程开发微信小程序-开始篇
微信小程序·小程序·ai编程