加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

微信小程序之自定义倒计时组件

发布时间:2020-12-14 19:20:12 所属栏目:资源 来源:网络整理
导读:最近写小程序写上瘾了,业务上需要实现一个倒计时的功能,考虑到可拓展以及使用方便,便将其封装成组件(写习惯了JSX不得不吐槽小程序自定义组件的繁琐) 萌新第一次在掘金写东西,东西比较简单可能拉低整个掘金的文章水平了(求轻喷~) 需求 可配置倒计时的时间 倒
  • 最近写小程序写上瘾了,业务上需要实现一个倒计时的功能,考虑到可拓展以及使用方便,便将其封装成组件(写习惯了JSX不得不吐槽小程序自定义组件的繁琐)
  • 萌新第一次在掘金写东西,东西比较简单可能拉低整个掘金的文章水平了(求轻喷~)

需求

  • 可配置倒计时的时间
  • 倒计时结束后执行事件
  • 可配置倒计时时间的格式

步骤

  • 先定义自定义组件的?properties?,这里有两个父组件传给该倒计时组件的参数?target?倒计时的时间,?format?倒计时时间的格式
properties: {
    target: {
      type: String,},format: {
      type: Function,default: null
    }
},复制代码
  • 定义组件生命周期函数
lifetimes: {
    attached() {
      //组件创建时
      this.setData({
        lastTime: this.initTime(this.properties).lastTime,//根据 target 初始化组件的lastTime属性
      },() => {
        //开启定时器
        this.tick();
        //判断是否有format属性 如果设置按照自定义format处理页面上显示的时间 没有设置按照默认的格式处理
        if (typeof this.properties.format === 'object') {
          this.defaultFormat(this.data.lastTime)
        }
      })
    },detached() {
      //组件销毁时清除定时器 防止爆栈
      clearTimeout(timer);
    },复制代码

微信小程序自定义组件的生命周期指的是指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发。其中,最重要的生命周期是?created?attached?detached?,包含一个组件实例生命流程的最主要时间点。具体微信自定义组件学习参考官方文档

  • 定义组件自身的状态
/**
 * 组件的初始数据
*/
data: {
    d: 0,136);">//天
    h: //时
    m: //分
    s: //秒
    result: '',136);">//自定义格式返回页面显示结果
    lastTime:''  //倒计时的时间错
},复制代码
  • 组件自身的方法
methods: {
    //默认处理时间格式
    defaultFormat: function(time) {
      const day = 24 * 60 * 1000
      const hours = 1000;
      const minutes = 1000;

      const d = Math.floor(time / day);
      const h = Math.floor((time - d * day) / hours);
      const m = Math.floor((time - d * day - h * hours) / minutes);
      const s = Math.floor((time - d * day - h * hours - m * minutes) / 1000);
      this.setData({
        d,h,m,s
      })
    },136);">//定时事件
    tick: function() {
      let {
        lastTime
      } = this.data;

      timer = setTimeout(() => {
        if (lastTime < interval) {
          clearTimeout(timer);
          this.setData({
              lastTime: result: ''
            },() => {
              this.defaultFormat(lastTime)
              if (this.onEnd) {
                this.onEnd();
              }
            }
          );
        } else {
          lastTime -= interval;
          this.setData({
              lastTime,result: this.properties.format ? this.properties.format(lastTime) : this.tick();
            }
          );
        }
      },interval);
    },136);">//初始化时间
    initTime: function(properties) {
      let lastTime = 0;
      let targetTime = try {
        if (Object.prototype.toString.call(properties.target) === '[object Date]') {
          targetTime = Number(properties.target).getTime();
        } else {
          targetTime = new Date(Number(properties.target)).getTime();
        }
      } catch (e) {
        throw Error('invalid target properties',e);
      }

      lastTime = targetTime - Date().getTime();
      return {
        lastTime: lastTime < 0 ? 0 : lastTime,};
    },136);">//时间结束回调事件
    onEnd: this.triggerEvent('onEnd');
    }
  }
复制代码

defaultFormat?:默认时间处理函数?tick?:定时事件?initTime?初始化时间?onEnd?:时间结束的回调

  • 倒计时组件?countDown.js?完整代码
var timer = 0;
var interval = 1000;
Component({
  /**
   * 组件的属性列表
   */
  properties: {
    target: {
      type: String,format: {
      type: Function,default: null
    }
  },lifetimes: {
    attached() {
      this.setData({
        lastTime: typeof this.data.lastTime)
        }
      })
    },136);">/**
   * 组件的初始数据
   */
  data: {
    d: //天
    h: //时
    m: //分
    s: //秒
    result: //自定义格式返回页面显示结果
    lastTime://倒计时的时间错
  },136);">/**
   * 组件的方法列表
   */
  methods: {
    'onEnd');
    }
  }
})
复制代码
  • 倒计时组件?countDown.wxml?完整代码
<wxs src="../wxs/utils.wxs" module="utils" />
<"../../comm.wxs" module="comm" />
<view class="count-down">
  <text wx:if="{{result!==''}}">{{result}}text>
  <block wx:else>
    <"{{comm.numberToFixed(d)>0}{{d}}天text>
    <text>{{utils.fixedZero(h)}}text>
    <{{utils.fixedZero(m)}}text>
  block>
view>
复制代码

其中引入了两个wxs文件中的函数

WXS(WeiXin Script)是小程序的一套脚本语言,结合 WXML,可以构建出页面的结构。官方文档

function fixedZero(val) {
  return val * 1 < 10 ? '0' + val : val;
}
//保留 pos位小数
numberToFixed(number,pos) {
  number === null || number === '' || number < 0) return ''
  return parseFloat(number).toFixed(pos)
}
复制代码

组件使用

  • 引入方式
"usingComponents": {
    "countDown": "../../../components/countDown/countDown"
  },复制代码
  • 代码演示
countDown bind:onEnd="getPageList" format={{formatTime}}" target={{creatTargetTime}}" />
复制代码
const formatChinaDate = mss => {
  let days = parseInt(mss / (1000 * 24));
  let hours = parseInt((mss % (24)) / (60));
  let minutes = 60)) / (let seconds = 60)) / 1000);
  return days + ' 天 ' + hours + ' 小时 ' + minutes + ' 分钟 ' + seconds + ' 秒 ';
};
data:{
    formatTime:formatChinaDate,creatTargetTime:1556428889000,136);">//时间戳
}

getPageList:function(){
    //倒计时结束啦
    console.log('倒计时结束啦')
}
复制代码

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读