uniapp怎么实现一个页面有多个商品倒计时的效果
Admin 2022-06-23 群英技术资讯 1573 次浏览
这篇文章主要介绍“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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了如何在React中直接使用Redux,目前redux在react中使用是最多的,所以我们需要将之前编写的redux代码,融入到react当中去,本文给大家详细讲解,需要的朋友可以参考下
目录vue判断安卓还是IOS最近工作上遇到这样一个需求所以我们需要进行一个判断H5端判断安卓跟ios显示不同的背景图vue判断安卓还是IOS最近工作上遇到这样一个需求vue写的页面,需要同时跟安卓和ios进行交互;若是安卓,执行代码:android.finishActivity();若是IOS,执行代码:try {
目录1. 自定义组件官方文档1.1 创建自定义组件1.1.1 声明组件1.1.2 编辑组件1.2 使用自定义组件1.3 页面向自定义组件传递数据(父传子)1.4 组件将事件传给页面(子传父)1. 自定义组件小程序允许我们使用自定义组件的方式来构建页面。官方文档自定义组件是不是用的微信的组件感觉很爽啊,如果不够用怎么办?
JavaScript是一种前端开发语言,与其他高级语言一样,JavaScript也有new操作符。那么在js中new操作符的作用是什么呢?很多刚接触前端朋友对此都不是很了解,本文详细介绍了js中new操作符的作用,感兴趣的朋友继续往下看吧。
前端页面倒计时功能在很多场景中会用到,如很多秒杀活动等,本文主要介绍了用JS写了一个30分钟倒计时器的实现示例,感兴趣的可以了解一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008