uniapp微信小程序实现一个页面多个倒计时


Posted in Javascript onNovember 01, 2020

本文实例为大家分享了uniapp实现一个页面多个倒计时的具体代码,供大家参考,具体内容如下

设计图(需求)

uniapp微信小程序实现一个页面多个倒计时

结构

<view class="group-list" v-for="item in message" :key="item.productId">
 <view class="group-img" @click="navTo">
 <image :src="item.productPicture"></image>
 </view>
 <view class="group-info">
 <view class="product-name">{{ item.productName }}</view>
 <view class="product-price">
 <text class="discounts">¥{{ item.productCurrentPrice }}</text>
 <text class="original">¥{{ item.productMarketPrice }}</text>
 </view>
 <view class="group-partner">
 <scroll-view scroll-x>
 <view class="user-img">
 <view v-for="(single, index) in item.avatarList" :key="index">
 <image :src="single"></image>
 </view>
 <view v-for="i in item.stillMissingNumber" :key="i">
 <image src="../../static/ssll-img/more.png"></image>
 </view>
 </view>
 </scroll-view>
 <button open-type="share">邀请好友</button>
 </view>
 <view class="clock">
 <text>拼团剩余:</text>
 <!-- 绑定倒计时 -->
 <text>{{ item.end_time1 }}</text> 
 </view>
 </view>
</view>

js

export default {
 data() {
 return {
 timeData: '', //存放每条数据的处理好的倒计时
 timer: '', //用来清除定时器
 message: [] //接口请求返回的数据
 }
 },
 onUnload(){ //卸载页面清除定时器
 clearInterval(this.timer) 
 },
 methods: {
 getTimeList(){ 
 let that = this
 that.message.forEach((item) =>{
  var nowdate = new Date().getTime() //获取当前时间毫秒数
  var time = item.productExpiredTime.replace(new RegExp("-", "gm"), "/") //ios不能识别日期格式中的 "-" ; .productExpiredTime是接口返回的名称
  var timesp = time.split('.')[0] //此处是因为我们接口返回的时间格式是这样:"2019-12-31 11:00:00.0"
  var enddate = new Date(timesp).getTime() //处理好格式之后获取结束时间的毫秒数
  var totaltime = enddate - nowdate //获取时间差
  that.totaltime(totaltime) //这是下面封装的方法,将毫秒数处理成"xx时xx分xx秒"
  item.end_time1 = that.timeData //处理好的单个时间安排到item上(重要)
 })
 this.message = that.message //全部处理好的数据重新赋值
 },
 
 totaltime(a){ //计算单个剩余时间
 let totaltime = a
 let that = this
  var h, m, s, d
  function test(num) {
  if (num < 10) {
   num = "0" + num 
  }
  return num
  }
  
 if (totaltime > 0) {
  d = Math.floor(totaltime / 1000 / 60 / 60 / 24) * 24
  h = Math.floor(totaltime / 1000 / 60 / 60 % 24)
  m = Math.floor(totaltime / 1000 / 60 % 60)
  s = Math.floor(totaltime / 1000 % 60)
  //获取时分秒
  h = d + h
  h = test(h)
  m = test(m)
  s = test(s)
  
  this.timeData =`${h}时 : ${m}分 : ${s}秒` // 每个时间的显示格式
  
 } else {
  
  this.timeData = `00 : 00 : 00` 
  
 }
 },
 //以下请求此页面需要的数据
 getUserGroupList(接口参数) {
 this.$ajax({
 url: 'xxx/xxx/xxxxxx',
 data: {接口参数},
 success: res => {
 var that = this
 let data = res.data.groups
 if (data.length === 0) {
 this.$api.msg('暂时您还没有参团信息!')
 setTimeout (function() {
 uni.navigateBack({ //返回上一页
  delta: 1
 })
 },1500)
 } else {
 this.message = [...that.message, ...res.data.groups] //合并
 //数据返回成功之后再调计时器,防止异步
 //that.getTimeList()
 var timer = setInterval(function () {
  that.getTimeList()
 }, 1000)
 this.timer = timer
 }
 }
 }
}

至此,一个页面多个倒计时就完成了, 记录学习。

为大家推荐现在关注度比较高的微信小程序教程一篇:《微信小程序开发教程》小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript编程起步(第七课)
Jan 10 Javascript
初窥JQuery(二)事件机制(2)
Dec 06 Javascript
用jQuery模拟页面加载进度条的实现代码
Dec 19 Javascript
JavaScript获取/更改文本框的值的实例代码
Aug 02 Javascript
深入理解JavaScript高级之词法作用域和作用域链
Dec 10 Javascript
jQuery结合AJAX之在页面滚动时从服务器加载数据
Jun 30 Javascript
jQuery中$.each()函数的用法引申实例
May 12 Javascript
Bootstrap3使用typeahead插件实现自动补全功能
Jul 07 Javascript
富文本编辑器vue2-editor实现全屏功能
May 26 Javascript
Node.js API详解之 Error模块用法实例分析
May 14 Javascript
Vue登录拦截 登录后继续跳转指定页面的操作
Aug 04 Javascript
Ajax请求超时与网络异常处理图文详解
May 23 Javascript
uni-app使用countdown插件实现倒计时
Nov 01 #Javascript
uni-app实现获取验证码倒计时功能
Nov 01 #Javascript
uniapp电商小程序实现订单30分钟倒计时
Nov 01 #Javascript
详解JavaScript之Array.reduce源码解读
Nov 01 #Javascript
微信小程序实现星星评分效果
Nov 01 #Javascript
Express 配置HTML页面访问的实现
Nov 01 #Javascript
ant design vue 表格table 默认勾选几项的操作
Oct 31 #Javascript
You might like
浅析PHP中Collection 类的设计
2013/06/21 PHP
测试PHP连接MYSQL成功与否的代码
2013/08/16 PHP
PHP开发APP端微信支付功能
2017/02/17 PHP
基于swoole实现多人聊天室
2018/06/14 PHP
浅谈php的TS和NTS的区别
2019/03/13 PHP
checkbox 复选框不能为空
2009/07/11 Javascript
javascript 24小时弹出一次的代码(利用cookies)
2009/09/03 Javascript
JQuery 学习技巧总结
2010/05/21 Javascript
基于jquery的cookie的用法
2011/01/10 Javascript
面向对象的Javascript之三(封装和信息隐藏)
2012/01/27 Javascript
JS刷新框架外页面七种实现代码
2013/02/18 Javascript
js中符号转意问题示例探讨
2013/08/19 Javascript
JS如何将UTC格式时间转本地格式
2013/09/04 Javascript
json格式的时间显示为正常年月日的方法
2013/09/08 Javascript
抛弃Nginx使用nodejs做反向代理服务器
2014/07/17 NodeJs
js实现禁止中文输入的方法
2015/01/14 Javascript
javascript实现类似百度分享功能的方法
2015/07/27 Javascript
Javascript 调用 ActionScript 的简单方法
2016/09/22 Javascript
npm scripts 使用指南详解
2018/10/08 Javascript
javascript Canvas动态粒子连线
2020/01/01 Javascript
vue各种事件监听实例(小结)
2020/06/24 Javascript
Python实现CET查分的方法
2015/03/10 Python
在Python的web框架中配置app的教程
2015/04/30 Python
Python语言实现百度语音识别API的使用实例
2017/12/13 Python
python保存数据到本地文件的方法
2018/06/23 Python
对Python中列表和数组的赋值,浅拷贝和深拷贝的实例讲解
2018/06/28 Python
pycharm专业版远程登录服务器的详细教程
2020/09/15 Python
如何将anaconda安装配置的mmdetection环境离线拷贝到另一台电脑
2020/10/15 Python
Clarisonic美国官网:科莱丽声波洁面仪
2017/10/12 全球购物
ALDO加拿大官网:加拿大女鞋品牌
2018/12/22 全球购物
中学自我评价
2014/01/31 职场文书
学生个人自我鉴定
2014/03/26 职场文书
水知道答案观后感
2015/06/08 职场文书
煤矿施工安全协议书
2016/03/22 职场文书
最新农村养殖致富:资金投入较低的创业项目有哪些?
2019/09/26 职场文书
Promise静态四兄弟实现示例详解
2022/07/07 Javascript