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

今天给大家带来微信小程序倒计时组件具体开发步骤:

先来看下最终效果:

git源:http://git.oschina.net/dotton/CountDown

分步骤-性子急的朋友,可以直接看最后那段代码。

wxml文件放个text

<text>second: {{second}} micro second:{{micro_second}}</text>

在js文件中调用

function countdown(that) {  var second = that.data.second  if (second == 0) {    // console.log("Time Out...");
        that.setData({
          second: "Time Out..."
        });    return ;
      }  var time = setTimeout(function(){
        that.setData({
          second: second - 1
        });
        countdown(that);
      }
      ,1000)
    }
     
    Page({
        data: {
            second: 3
        },
        onLoad: function() {
            countdown(this);
        }
    });

运行验证下,从10走到1s,然后显示时间到。

于是继续将毫秒完善,注意毫秒的步长受限于系统的时间频率,于是我们精确到0.01s即10ms

js

/* 秒级倒计时 */function countdown(that) {  var second = that.data.second  if (second == 0) {
        that.setData({
          second: "Time out!",
          micro_second: "micro_second too."
        });
        clearTimeout(micro_timer);    return ;
      }  var timer = setTimeout(function(){
        that.setData({
          second: second - 1
        });
        countdown(that);
      }
      ,1000)
    }/* 毫秒级倒计时 */// 初始毫秒数,同时用作归零var micro_second_init = 100;// 当前毫秒数var micro_second_current = micro_second_init;// 毫秒计时器var micro_timer;function countdown4micro(that) {  if (micro_second_current <= 0) {
        micro_second_current = micro_second_init;
      }
      micro_timer = setTimeout(function(){
        that.setData({
          micro_second: micro_second_current - 1
        });
        micro_second_current--;
        countdown4micro(that);
      }
      ,10)
    }
     
    Page({
        data: {
            second: 2,
            micro_second: micro_second_init
        },
        onLoad: function() {
            countdown(this);
            countdown4micro(this);
        }
    });

wxml文件

<text style="display: block;">second: {{second}}s</text><text>{{micro_second}}</text>

如此,当秒级运行完毕时,毫秒级timer即clearTimeout,并将字本显示为‘micro_second too‘

再添加一个countdown4micro方法,使得显示剩余 0:3:19 89这样形式的倒数

function dateformat(second) {    var dateStr = "";    var hr = Math.floor(second / 3600);    var min = Math.floor((second - hr * 3600) / 60);    var sec = (second - hr * 3600 - min * 60);// equal to => var sec = second % 60;
        dateStr = hr + ":" + min + ":" + sec;    return dateStr;
    }

目前有2个时钟,影响性能,合并下去掉countdown,于是countdown4micro变成以下的样子:

function countdown4micro(that) {    var loop_second = Math.floor(loop_index / 100);    // 得知经历了1s
        if (cost_micro_second != loop_second) {        // 赋予新值
            cost_micro_second = loop_second;        // 总秒数减1
            total_second--;
     
        }      // 每隔一秒,显示值减1; 渲染倒计时时钟
        that.setData({
          clock:dateformat(total_second - 1)
        });      if (total_second == 0) {
            that.setData({          // micro_second: "",
              clock:"时间到"
            });
            clearTimeout(micro_timer);        return ;
          }    
     
      if (micro_second_current <= 0) {
        micro_second_current = micro_second_init;
      }
      micro_timer = setTimeout(function(){
        that.setData({
          micro_second: micro_second_current - 1
        });
        micro_second_current--;    // 放在最后++,不然时钟停止时还有10毫秒剩余
        loop_index ++;
        countdown4micro(that);
      }
      ,10)
    }

如此这般,毫秒与时分秒是分别运行渲染的,再次改造,程序可读性更好。dateformat针对于毫秒操作,而不接受秒为数。同时还省却了计算100次为1s的运算

/**
     * 需要一个目标日期,初始化时,先得出到当前时间还有剩余多少秒
     * 1.将秒数换成格式化输出为XX天XX小时XX分钟XX秒 XX
     * 2.提供一个时钟,每10ms运行一次,渲染时钟,再总ms数自减10
     * 3.剩余的秒次为零时,return,给出tips提示说,已经截止
     */// 定义一个总毫秒数,以一分钟为例。TODO,传入一个时间点,转换成总毫秒数var total_micro_second = 2 * 1000;/* 毫秒级倒计时 */function countdown(that) {      // 渲染倒计时时钟
          that.setData({
              clock:dateformat(total_micro_second)
          });      if (total_micro_second <= 0) {
              that.setData({
                  clock:"已经截止"
              });          // timeout则跳出递归
              return ;
          }    
          setTimeout(function(){        // 放在最后--
            total_micro_second -= 10;
            countdown(that);
        }
        ,10)
    }// 时间格式化输出,如3:25:19 86。每10ms都会调用一次function dateformat(micro_second) {      // 秒数
          var second = Math.floor(micro_second / 1000);      // 小时位
          var hr = Math.floor(second / 3600);      // 分钟位
          var min = Math.floor((second - hr * 3600) / 60);      // 秒位
        var sec = (second - hr * 3600 - min * 60);// equal to => var sec = second % 60;
        // 毫秒位,保留2位
        var micro_sec = Math.floor((micro_second % 1000) / 10);    return hr + ":" + min + ":" + sec + " " + micro_sec;
    }
     
    Page({
        data: {
            clock: ‘‘
        },
        onLoad: function() {
            countdown(this);
        }
    });

经过如上优化,代码量减少一半,运行效率也高了。
---------------------
作者:第九程序
来源:CSDN
原文:https://blog.csdn.net/qq_38125123/article/details/73459963?utm_source=copy
版权声明:本文为博主原创文章,转载请附上博文链接!

原文地址:https://www.cnblogs.com/behindman/p/9783209.html

时间: 2024-12-12 22:43:25

微信小程序倒计时组件开发的相关文章

微信小程序image组件开发程序以及相关图片问题参考资料汇总

微信小程序image组件开发程序以及相关图片问题参考资料汇总,希望对大家小程序开发能有一定的参考和借鉴价值.以下汇总主要涉及到微信小程序image组件有关资源路径.缩放和剪裁模式等进行的探讨,无论是对微信小程序新手还是正在开发中的朋友都是很好的小程序学习资料. 微信小程序image组件必备基础知识: image组件默认宽度300px.高度225px image的属性mode有13种模式,其中4种是缩放模式,9种是裁剪模式 image组件开发教程汇总: 微信小程序自定义组件实现图片单指拖动.双指缩

微信小程序image组件binderror使用例子(对应html、js中的onerror)

官方文档  binderror HandleEvent 当错误发生时,发布到 AppService 的事件名,事件对象event.detail = {errMsg: 'something wrong'} 在微信小程序开发中,我们使用列表包含图片,如果这个图片链接404错误,那么我们应该给它提供一个默认的友好URL地址.html和js中使用onerror事件就可以了 <img src="image.gif" onerror="this.src='https:w.chesu

iView Weapp微信小程序UI组件库中i-input的使用

iView Weapp微信小程序UI组件库为小程序的开发提供了良好的交互界面,组件库自定义了一系列组件,具有较强的开发友好性,但一些组件与微信小程序原生组件的使用方式有差异. i-input组件是该框架自定义的输入框组件,与微信中input具有相同功能. 在使用i-input输入值时,可以增加其bind:change="myInput" 属性,如: wxml: <i-input type="number" right  maxlength="2&qu

微信+小程序购物系统开发微信小程序营销系统开发

行业+小程序的结合有无限可能性,想要玩转微信小程序,享受流量盛宴,可借助--河南鼎汉科技,帮您快速打造具有个性化特色的微信小程序.微信小程序系统开发平台.微信小程序购物商城系统开发1.8.8-3.8.07-6.8.0.5电/微, 微信小程序 微商城 微信小程序营销系统开发,微信公众平台订阅号,微信小程序购物商城系统开发定制. 在移动互联网时代从来不缺分销系统,随着移动电商.传统电商.传统商业企业纷纷进入社交电商领域,社交电商正在向专业平台化.团队规模化.渠道立体化.运作规范化等趋势发展.微信"小

微信小程序图表组件 wx-f2

摘自 杀个程序猿祭天  https://www.jianshu.com/p/6b9fe45f799f Github地址:https://github.com/antvis/wx-f2 AntV F2地址: AntV F2 微信小程序图表组件 wx-f2,源于 F2,专为移动而生 F2,专为移动而生的可视化解决方案,特为大家提供了微信小程序端版本,体积小巧,性能卓越,底层基于图形语法,可以提供非常丰富的图表类型. 可以使用微信扫描以下二维码先体验一番: image wx-f2 F2 的微信小程序版

微信小程序picker组件 - 省市二级联动

微信小程序picker组件自带省市区选择器,但是业务需求需要省市选择器,参考官方demo自己写了一个省市选择器 wxml文件 <view class="section"> <view class="section__title">省市二级联动demo</view> <picker mode="multiSelector" bindchange="bindMultiPickerChange&quo

微信小程序气泡组件

资料 网址 微信小程序气泡组件 https://github.com/byk04712/weapp-popover 原文地址:https://www.cnblogs.com/cag2050/p/12605725.html

微信小程序(应用号)开发教程

本文档将带你一步步创建完成一个微信小程序,并可以在手机上体验该小程序的实际效果.这个小程序的首页将会显示欢迎语以及当前用户的微信头像,点击头像,可以在新开的页面中查看当前小程序的启动日志.下载源码 1. 获取微信小程序的 AppID 如果你是收到邀请的开发者,我们会提供一个帐号,利用提供的帐号,登录 https://mp.weixin.qq.com ,就可以在网站的“设置”-“开发者设置”中,查看到微信小程序的 AppID 了,注意不可直接使用服务号或订阅号的 AppID . 如果没有收到内测邀

微信小程序UI组件、开发框架、实用库

UI组件 weui-wxss ★852 - 同微信原生视觉体验一致的基础样式库 Wa-UI ★122 - 针对微信小程序整合的一套UI库 wx-charts ★105 - 微信小程序图表工具 wemark ★85 - 微信小程序Markdown渲染库 WeZRender ★36 - 微信小程序Canvas增强组件 wetoast ★21 - 仿照微信小程序提供的showToast功能 wxapp-charts ★20 - 微信小程序图表charts组件 WeiXinProject ★18 - 列