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

先来看下最终效果:

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
版权声明:本文为博主原创文章,转载请附上博文链接!

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

  1. 微信小程序official-account组件开发

    今天微信公众平台发了一条消息 扫码打开小程序新增公众号关注组件 官方apihttps://developers.weixin.qq.com/miniprogram/dev/component/offi ...

  2. 微信小程序之组件开发中的基础知识

    跟着视频开始小程序的项目的开发,视频中这个小程序已经上线了,可以很好的看着小程序的界面进行开发,昨天看了一下具体的需求,觉得真的细节好多啊,而且其中设计的组件的思想也是很好的,能够很好的实现代码的复用 ...

  3. 微信小程序 MinUI 组件库系列之 price 价格组件

    MinUI 是基于微信小程序自定义组件特性开发而成的一套简洁.易用.高效的组件库,适用场景广,覆盖小程序原生框架.小程序组件化框架等,并且提供了高效的命令行工具.MinUI 组件库包含了很多基础的组件 ...

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

    官方文档  binderror HandleEvent 当错误发生时,发布到 AppService 的事件名,事件对象event.detail = {errMsg: 'something wrong' ...

  5. 微信小程序的功能开发工具跟公众号的差别,小程序是一种减负思维对简单APP是巨大打击

    微信小程序的功能开发工具跟公众号的差别,小程序是一种减负思维对简单APP是巨大打击 摘要: 小程序和公众号最大的区别有如下四点:1.小程序没有粉丝,开发者在后台能看到的只能是累计用户访问数以及实时统计 ...

  6. 5个最优秀的微信小程序UI组件库

    开发微信小程序的过程中,选择一款好用的组件库,可以达到事半功倍的效果.自从微信小程序面世以来,不断有一些开源组件库出来,下面5款就是排名比较靠前,用户使用量与关注度比较高的小程序UI组件库.还没用到它 ...

  7. 微信小程序弹窗组件

    概述 自己封装的一个比较简单微信弹窗小组件,主要就是教会大家对微信小组件的用法和理解,因为微信小程序对组件介绍特别少,所以我就把自己的理解分享给大家 详细 代码下载:http://www.demoda ...

  8. Wuss Weapp 一款高质量,组件齐全,高自定义的微信小程序 UI 组件库

    Wuss Weapp 一款高质量,组件齐全,高自定义的微信小程序 UI 组件库 文档 https://phonycode.github.io/wuss-weapp 扫码体验 使用微信扫一扫体验小程序组 ...

  9. 6个最优秀的微信小程序UI组件库

    开发微信小程序的过程中,选择一款好用的组件库,可以达到事半功倍的效果.自从微信小程序面世以来,不断有一些开源组件库出来,下面6款就是排名比较靠前,用户使用量与关注度比较高的小程序UI组件库.还没用到它 ...

随机推荐

  1. BZOJ 4614[Wf2016]Oil

    权限题鸭qwq 首先可以知道最优答案选出来的直线一定可以经过某条线段左端点,如果这条直线没有过左端点,可以通过平移和旋转等操作达到.所以可以枚举这条直线过了哪条线段的左端点,那么对于其他线段,能对答案 ...

  2. SpringMVC使用Burlap发布远程服务

    参考这篇文章https://www.cnblogs.com/fanqisoft/p/10283156.html 将提供者配置类中的 @Bean public HessianServiceExporte ...

  3. linux源码Makefile详解(完整)

    转自:http://www.cnblogs.com/Daniel-G/p/3286614.html 随着 Linux 操作系统的广泛应用,特别是 Linux 在嵌入式领域的发展,越来越多的人开始投身到 ...

  4. python计算最大公约数和最小公倍数

    a=4 b=2 def gcd(a,b): return a if b==0 else gcd(b,a%b) def lcm(a,b): return a*b//gcd(a,b) print(gcd( ...

  5. ES系列目录

    ES系列一.CentOS7安装ES 6.3.1 ES系列二.CentOS7安装ES head6.3.1 ES系列三.基本知识准备 ES系列四.ES6.3常用api之文档类api ES系列五.ES6.3 ...

  6. WebRTC服务器——Licode 环境搭建

    WebRTC服务器--Licode 环境搭建 系统配置 阿里云服务器 Ubuntu 14.04.5 LTS Docker 环境搭建 在一台空的机器上搭建docker环境,先要安装docker,执行下面 ...

  7. mysql当查询某字段结果为空并赋值

    1 代码 1.1 当当前字段为空,查询结果返回“none”,并且统计出现频率 select case when 字段 is null then 'none' else 字段 end as 字段, co ...

  8. Java中日期格式化SimpleDateFormat类包含时区的处理方法

    1.前言 需要把格式为“2017-02-23T08:04:02+01:00”转化成”23-02-2017-T15:04:02“格式(中国时区为+08:00所以是15点),通过网上查找答案,发现没有我需 ...

  9. flexible array柔性数组、不定长的数据结构Struct详解

    柔性数组,这个名词对我来说算是比较新颖的,在学习跳跃表的实现时看到的.这么好听的名字,的背后到底是如何的优雅. 柔性数组,其名称的独特和迷惑之处在于“柔性”这个词.在C/C++中定义数组,是一个定长的 ...

  10. 如何将Request对象中的参数列表打印出来

    Map<String, String[]> map = request.getParameterMap(); Set<Map.Entry<String, String[]> ...