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

先来看下最终效果:

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. MySQL指令

    在mysql里:文件夹就是数据库      文件就是表 创建用户: 格式:create user '用户名'@'IP地址' identified by '密码'; 说明:IP地址是用来限制用户只能在哪 ...

  2. redis实现消息队列&发布/订阅模式使用

    在项目中用到了redis作为缓存,再学习了ActiveMq之后想着用redis实现简单的消息队列,下面做记录.   Redis的列表类型键可以用来实现队列,并且支持阻塞式读取,可以很容易的实现一个高性 ...

  3. 【漏洞分析】两个例子-数组溢出修改返回函数与strcpy覆盖周边内存地址

    修改返回函数 return 0 下面的程序的运行流程为main()函数调用了Magic()函数,通常执行完Magic()函数后会调用return 0 的地址, 但是在执行Magic()函数中时,数组下 ...

  4. 【转】Python之函数进阶

    [转]Python之函数进阶 本节内容 上一篇中介绍了Python中函数的定义.函数的调用.函数的参数以及变量的作用域等内容,现在来说下函数的一些高级特性: 递归函数 嵌套函数与闭包 匿名函数 高阶函 ...

  5. c# WinFo判断当前程序是否已经启动或存在的几种方式

    第一种方式:利用Mutex互斥量实现同时只有一个进程实例在运行 static class Program { /// <summary> /// 应用程序的主入口点. /// </s ...

  6. c++ 引用方式传递数组

    值传递 (pass by value),指针传递(pass by pointer),当发生函数调用时,需要给形参分配存储单元.当传递是对象时,要调用拷贝构造函数.而且指针最后析构时,要处理内存释放问题 ...

  7. centos6.5环境openldap实战之ldap配置详解及web管理工具lam(ldap-account-manager)使用详解

    ldap常用名称解释 1.环境搭建 操作系统:centos6.5 x86_64 关闭防火墙.selinux 开启时间同步 # crontab -e 加入 # time sync */5 * * * * ...

  8. Expm 8_1 区间划分问题

      [问题描述] 给定一组报告,其中的每个报告设置了一个开始时间si和结束时间fi.设计与实现一个算法,对这组报告分配最少数量的教室,使得这些报告能无冲突的举行. package org.xiu68. ...

  9. oracle中REGEXP_SUBSTR方法的使用

    近期在做商旅机票平台,遇到这样一个问题: 有一张tt_ticket表,用来存机票信息.里边有一个字段叫schedule,表示的是行程,存储格式为:北京/虹桥 由于公司位于上海.而上海眼下有两个机场:浦 ...

  10. yield()方法就是礼让,具体还是看cpu怎么分配

    package charpter07; //yield():礼让的行为public class Processor implements Runnable { @Override public voi ...