解决uni-countdown动态赋值变更时间倒计时无变化的问题

在Vue的uni-app项目中,遇到倒计时组件根据服务器返回的数据更新不生效的问题。倒计时组件(uni-countdown)在使用this.$refs.countdown.update()方法时表现不稳定,有时工作,有时不工作,且影响范围仅限当前页面。为解决此问题,尝试通过v-if控制组件的销毁和重建,先将showCount设为false,更新goodsInfo.end_date,然后在$nextTick中恢复showCount为true以触发组件重建。然而,这种方法要求手动设置倒计时来刷新数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

倒计时根据服务器返回的数据更新倒计时

重新赋值更新时间后无反应

使用this.$refs.countdown.update()时而有效时而无效且只针对当前页面有反应

只有重新刷新该组件才能更新数据

通过v-if实现组件的销毁和重建

<uni-countdown :font-size="10" :show-day="countDown(goodsInfo.end_date)[0]==0?false:true" :day="countDown(goodsInfo.end_date)[0]" :hour="countDown(goodsInfo.end_date)[1]" :minute="countDown(goodsInfo.end_date)[2]" :second="countDown(goodsInfo.end_date)[3]" color="#F7263D" background-color="#FFFFFF" splitorColor="#FFFFFF" v-if="showCount"/>
data() {
      return {
        showCount: true,
        goodsInfo:{}
      };
    },

更新时间前先将倒计时组件进行销毁,更新数据后再进行重建(不过此处需设置倒计时才能进行倒计时数据刷新)

this.showCount = false
this.goodsInfo.end_date = e.end_date
this.$nextTick(()=>{
  this.showCount = true
})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值