微信小程序倒计时组件更新,加入时间校准、多计时器功能
微信小程序倒计时组件更新,加入时间校准、多计时器功能
第九程序 发表于7个月前
微信小程序倒计时组件更新,加入时间校准、多计时器功能
  • 发表于 7个月前
  • 阅读 17
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 技术升级10大核心产品年终让利>>>   

摘要: 针对在IOS下息屏和挂起状态下倒计时不会继续,以及在安卓状态下息屏导致变慢的问题进行的一次更新,具体效果请参考小程序 番茄闹钟。

针对在IOS下息屏和挂起状态下倒计时不会继续,以及在安卓状态下息屏导致变慢的问题进行的一次更新,具体效果请参考小程序 番茄闹钟。

暂时无法解决的痛点: 
1、在息屏和挂起下的倒计时结束以后需要跳转页面,但是有部分解决方案可以看我之前写的帖子,在这里 
2、倒计时结束以后的函数,以及每隔多少秒执行的函数都不会执行,只有在重新进来之后才会执行。

wxTimer

介绍:用于在微信小程序中进行倒计时的组件。 
功能
1、最基础的当然就是倒计时功能了。 
2、可以设置倒计时结束后执行的事件。 
3、可以设置倒计时执行过程中每隔多少秒,执行一次对应的事件。

用法 
引入:

var timer = require('../../plugins/wxTimer.js');

最简单的调用方式:

var wxTimer = new timer({

  beginTime:"00:00:10"

})

wxTimer.start(this);

wxTimer.stop();

倒计时结束后执行事件:

var wxTimer = new timer({

    beginTime:"00:00:10",

    complete:function(){

        console.log("完成了")

    }

})

wxTimer.start(this);

wxTimer.stop();

间隔执行事件:

var wxTimer = new timer({

    beginTime:"00:00:10",

    complete:function(){

        console.log("完成了")

    },

    interval:2,

    intervalFn:function(){

        console.log("过去了2秒");

    }

})

校准时间:

wxTimer.calibration();

注意: 
1、由于内部需要调用到小程序的setData方法,所以我们需要把this传过去。 
2、此方法会在page中生成一个名为wxTimer和wxTimerSecond的data,分别是倒计时的 时/分/秒 版本和倒计时的纯秒数版本,如果需要在wxml中引用倒计时的数据直接{{wxTimer}}或者{{wxTimerSecond}}即可

其他参数: 
1、beginTime 需要倒计时的时间,比如:"01:11:12",默认值为"00:00:00",也可以省略秒数,如:"01:10" 
2、complete 倒计时归零0时的回调函数,如果为beginTime = "00:00:00"则立即调用 
3、interval 倒计时的过程中,规定每隔几秒执行一次intervalFn,如果为0则永远不会执行,默认为1 
4、intervalFn 每隔interval秒执行一次的函数。

历史更新 

2017.03.22 应对在息屏和挂起状态下倒计时无法进行的问题,加入了校准功能,可以在onShow()函数中直接调用wxTimer.calibration()来校准时间。

共有 人打赏支持
粉丝 75
博文 142
码字总数 172691
×
第九程序
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: