当前位置: 首页 > news >正文

uni-app vue3 实现72小时倒计时功能

功能介绍 ,数组项有一个下单时间 ,比如今天下单在72小时内可以继续支付,超过则默认取消订单

在这里插入图片描述

  1. 页面按钮处 加上倒计时
<!-- 倒计时 -->
<text v-if="item.timeLeft > 0">{{ formatTime(item.remaining) }}</text>
  1. 逻辑处理
// 第一步 处理接口返回的数据 原本是没有倒计时 remaining这个值的 我们根据状态给数组项加上
console.log("列表数据", res);
res.forEach((item) => {if (item.actions.pay) {const createTime = new Date(item.create_time).getTime(); // 下单时间处理item.endTime = createTime + 72 * 3600 * 1000; // 计算72小时截止时间item.remaining = 0; // 剩余时间(毫秒)item.timeLeft = true; // 倒计时状态}
})
updateAllTimers();// 第二步 统一定时器
let timer;// 第三步 更新所有倒计时
const updateAllTimers = () => {const now = Date.now();listData.value.forEach(item => {const diff = item.endTime - now;item.remaining = diff;item.timeLeft = diff > 0;});
};// 第四步 时间格式化函数
const formatTime = (milliseconds) => {if (milliseconds <= 0) return '00:00:00';const totalSeconds = Math.floor(milliseconds / 1000);const hours = Math.floor(totalSeconds / 3600).toString().padStart(2, '0');const minutes = Math.floor((totalSeconds % 3600) / 60).toString().padStart(2, '0');const seconds = (totalSeconds % 60).toString().padStart(2, '0');return `${hours}:${minutes}:${seconds}`;
};// 生命周期管理
onMounted(() => {timer = setInterval(updateAllTimers, 1000);
});// 卸载
onUnmounted(() => {clearInterval(timer);
});

相关文章:

  • 从普查到防控:ArcGIS洪水灾害全流程分析技术实战——十大专题覆盖风险区划/淹没制图/水文分析/洪水分析/淹没分析/项目交流,攻克防洪决策数据瓶颈!
  • 「Mac畅玩AIGC与多模态05」部署篇03 - 在 Mac 上部署本地向量化模型(Embedding Models)
  • Deepseek-v3+cline+vscode java自动化编程
  • codeforcesB. Alice‘s Adventures in Permuting
  • VSCode 查看文件的本地修改历史
  • 推荐 1 款 9.3k stars 的全景式开源数据分析与可视化工具
  • STM32完整内存地址空间分配详解
  • 小目标检测的集成融合论文阅读
  • 智能制造典型场景参考指引(2025年版)
  • Server-Sent Events (SSE) 服务端单项实时给前端推送消息
  • 基于ffmpeg的音视频编码
  • 复合模式(Composite Pattern)
  • 【Java开发日记】OpenFeign 的 9 个坑
  • Meta 推出 WebSSL 模型:探索 AI 无语言视觉学习,纯图训练媲美 OpenAI CLIP
  • 深入浅出限流算法(三):追求极致精确的滑动日志
  • leetcode283-移动零
  • 【神经网络与深度学习】两种加载 pickle 文件方式(joblib、pickle)的差异
  • uniapp自定义头部(兼容微信小程序(胶囊和状态栏),兼容h5)
  • 深度解析算法之分治(归并)
  • el-table 自定义列、自定义数据
  • 千亿市值光储龙头董事长向母校合肥工业大学捐赠1亿元
  • 超级干细胞有助改善生育治疗
  • 俄联邦安全局:俄军高级官员汽车爆炸案嫌疑人已被捕
  • 应勇:以法治力量服务黄河流域生态保护和高质量发展
  • 体坛联播|皇马上演罢赛闹剧,杨瀚森宣布参加NBA选秀
  • 释新闻|印度宣布“掐断”巴基斯坦水源,对两国意味着什么?