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

先来看下最终效果:

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. Java垃圾回收机制复习

    一.如何确定某个对象是“垃圾” 二.典型的垃圾收集算法 三.典型的垃圾收集器 JVM(HotSpot) 7种垃圾收集器的特点及使用场景 https://www.cnblogs.com/chengxuy ...

  2. Android勒索软件研究报告

    Android勒索软件研究报告 Author:360移动安全团队 0x00 摘要 手机勒索软件是一种通过锁住用户移动设备,使用户无法正常使用设备,并以此胁迫用户支付解锁费用的恶意软件.其表现为手机触摸 ...

  3. ubuntu下tensorflow 报错 libcusolver.so.8.0: cannot open shared object file: No such file or directory

    解决方法1. 在终端执行: export LD_LIBRARY_PATH=”$LD_LIBRARY_PATH:/usr/local/cuda/lib64” export CUDA_HOME=/usr/ ...

  4. AT91RM9200---SMC简介

    1.前言 SMC(Static Memory Controller)Atmel 9200静态存储控制器的简称,它可以产生信号来控制外部静态存储和外设.SMC可通过编程寄存器来进行配置. 它有8路片选和 ...

  5. ubuntu 的 apt-get update 出现404错误时,或者添加ppa失败时,ubuntu 版本也 end of life 了的解决方案

    xmodulo.com/how-to-fix-apt-get-update-error-on-ubuntu.html 如果是依赖没找到,可以用 sudo apt-get install -f 先补齐依 ...

  6. 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( ...

  7. ES系列十九、kibana基本查询、可视化、仪表盘用法

    一. 定义索引模式匹配 1.前缀模糊匹配,一个模式匹配多个索引 每一个数据集导入到Elasticsearch后会有一个索引匹配模式,在上段内容莎士比亚数据集有一个索引名称为shakespeare,账户 ...

  8. notepad++64位添加plugin manager

    - 64位的notepad++,下载下来似乎没有plugin manager,如果真没有可以下载plugin manager. - plugin manager的下载地址:https://github ...

  9. Android OAuth认证

    OAuth认证 为了安全地访问在线服务,用户需要在服务上进行身份验证,即要提供他们的身份的证明.对于一个要访问第三方服务的程序来说,安全问题甚至更复杂.不仅仅是用户需要在访问服务前要进行身份验证,而且 ...

  10. 最全Kafka 设计与原理详解【2017.9全新】

    一.Kafka简介 1.1 背景历史 当今社会各种应用系统诸如商业.社交.搜索.浏览等像信息工厂一样不断的生产出各种信息,在大数据时代,我们面临如下几个挑战: 如何收集这些巨大的信息 如何分析它 如何 ...