vant_ CountDown倒计时

语法可以直接在官网查看

需求

后端返回的数据格式如下

javascript 复制代码
[
  {
      "id": 1,
      "btn_text": "+1",
      "second": 0
  },
  {
      "id": 2,
      "btn_text": "+1",
      "second": 0
  }
 ...
]

之前约定second最多30s, 因此只需要使用秒不需要使用分钟或者是小时。

在此处使用van-count-down 组件来完成的。

javascript 复制代码
<li v-for='item in getCountList' >
  <template v-if="item.second && !item.secondFinish">
    <van-count-down :time="item.second*1000" @finish="item.secondFinish = true">
      <template #default="timeData">
        <span class="block">{{ timeData.seconds }}S</span>
      </template>
    </van-count-down>
  </template>
  <template v-else>{{ item.btn_text }}</template>
</li>
问题

测试时发现 倒计时25S、24S ... 0S 之后并没有显示按钮文本"+1"而是显示60S继续开始倒计时

25S、24S ... 0S、60S、59S、58S ... 0S、60S ...

原因

后端返回的second数值为 325(不符合约定数值)

  • 我以为的:
    • [1] 会换算成时分秒 325s为30min25s
    • [2] timeData.seconds获取秒数为25
    • [3] 25S进行倒计时,倒计时结束触发finish方法
  • 实际上
    • [1] 将所有数据换算成秒以60s为一组 如[25s, 60s, 60s..., 60s]
    • [2] 进行倒计时,将所有组倒计时结束才会走finish方法!
      示例: 先对25s进行倒计时,然后对60s进行倒计时 ...所有60s倒计时结束,触发finish。
解决

只需要后端返回正确的秒数即可(<=30)。

相关推荐
学不会•41 分钟前
css数据不固定情况下,循环加不同背景颜色
前端·javascript·html
活宝小娜3 小时前
vue不刷新浏览器更新页面的方法
前端·javascript·vue.js
程序视点3 小时前
【Vue3新工具】Pinia.js:提升开发效率,更轻量、更高效的状态管理方案!
前端·javascript·vue.js·typescript·vue·ecmascript
coldriversnow3 小时前
在Vue中,vue document.onkeydown 无效
前端·javascript·vue.js
我开心就好o3 小时前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
开心工作室_kaic4 小时前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
刚刚好ā4 小时前
js作用域超全介绍--全局作用域、局部作用、块级作用域
前端·javascript·vue.js·vue
沉默璇年5 小时前
react中useMemo的使用场景
前端·react.js·前端框架
yqcoder6 小时前
reactflow 中 useNodesState 模块作用
开发语言·前端·javascript
2401_882727576 小时前
BY组态-低代码web可视化组件
前端·后端·物联网·低代码·数学建模·前端框架