uniapp怎么实现一个页面有多个商品倒计时的效果
Admin 2022-06-23 群英技术资讯 1696 次浏览
这篇文章主要介绍“uniapp怎么实现一个页面有多个商品倒计时的效果”,有一些人在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
}
}
}
}
至此,一个页面多个倒计时就完成了, 记录学习。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章我们来了解jQuery中实现替换类样式的方法,这里介绍两种方法,分别是addClass()方法和attr()方法,具体怎样实现呢?下文代码介绍的很详细,有需要的朋友可以参考,接下来就跟随小编来一起学习一下吧!
线程和进程是计算机操作系统的基础概念,在程序员中属于高频词汇,那如何理解呢?Node.js 中的进程和线程又是怎样的呢?下面本篇文章就来一起了解一下,希望对大家有所帮助!
这篇文章主要介绍了vue element和nuxt的使用技巧分享,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
JavaScript跨域请求携带cookie怎样实现的,有不少朋友对此感兴趣,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。
这篇文章主要介绍了JavaScript中 querySelector 与 getElementById 方法与区别,围绕querySelector 与 getElementById 的相关资料展开文章内容,需要的朋友可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008