index.js 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. import {
  2. getActivities
  3. } from '~/api/global'
  4. Component({
  5. properties: {},
  6. /**
  7. * 组件的初始数据
  8. */
  9. data: {
  10. //,2:邀新榜,3:热播榜,4:挑战pk榜,5,朗读赛
  11. type: '4',
  12. activityList: [{
  13. id: 1,
  14. name: '新学期限时充值活动',
  15. closing: '2023-1-29 16:38:00',
  16. }, {
  17. id: 2,
  18. name: '入学限时充值活动',
  19. closing: '2023-1-30 16:38:00',
  20. }],
  21. dsqList: []
  22. },
  23. lifetimes: {
  24. attached() {
  25. this.getActivities()
  26. },
  27. detached() {
  28. this.data.dsqList.forEach(item => {
  29. clearInterval(item)
  30. })
  31. }
  32. },
  33. /**
  34. * 组件的方法列表
  35. */
  36. methods: {
  37. async getActivities() {
  38. let res = await getActivities()
  39. this.data.activityList.forEach((item, index) => {
  40. this.activityTimeOut(item.closing, index)
  41. })
  42. },
  43. activityTimeOut(oTime,index) {
  44. let inputTime = new Date(oTime)
  45. let dsq = setInterval(() => {
  46. var nowTime = new Date();
  47. //把剩余时间毫秒数转化为秒
  48. var times = (inputTime - nowTime) / 1000;
  49. if (times <= 0) {
  50. this.setData({
  51. [`activityList[${index}].hour`]: '00',
  52. [`activityList[${index}].minute`]: '00',
  53. [`activityList[${index}].second`]: '00',
  54. })
  55. return clearInterval(dsq)
  56. }
  57. //计算小时数 转化为整数
  58. var h = parseInt(times / 60 / 60 % 24);
  59. //如果小时数小于 10,要变成 0 + 数字的形式 赋值给盒子
  60. let hour = h < 10 ? "0" + h : h;
  61. //计算分钟数 转化为整数
  62. var m = parseInt(times / 60 % 60);
  63. //如果分钟数小于 10,要变成 0 + 数字的形式 赋值给盒子
  64. let minute = m < 10 ? "0" + m : m;
  65. //计算描述 转化为整数
  66. var s = parseInt(times % 60);
  67. //如果秒钟数小于 10,要变成 0 + 数字的形式 赋值给盒子
  68. let second = s < 10 ? "0" + s : s;
  69. this.setData({
  70. [`activityList[${index}].hour`]: hour,
  71. [`activityList[${index}].minute`]: minute,
  72. [`activityList[${index}].second`]: second,
  73. })
  74. times = --times;
  75. }, 1000);
  76. this.setData({
  77. dsqList: [...this.data.dsqList, dsq]
  78. })
  79. }
  80. }
  81. })