Vue组件强制刷新(重新渲染)的四种方案对比

本文探讨了在Vue中如何在特定情况下手动触发组件更新,重点介绍了$forceUpdate方法和通过改变key来优化组件更新的策略。$forceUpdate()强制更新视图,而更改组件的key则会导致组件重新渲染。这两种方式在处理某些场景时非常有用。
摘要由CSDN通过智能技术生成

Vue的双向绑定用着确实方便,但自动档虽好,手动档也不是一无是处;在特定的情况下,还真的要手工触发“刷新”操作,目前有四种方案可以选择:

  1. 刷新整个页面(最low的,可以借助route机制)this.$router.go(0)
  2. 使用v-if标记(比较low的)
  3. 使用内置的forceUpdate方法(较好的)
  4. 使用key-changing优化组件(最好的)

前面两种种不多介绍了,我们重点介绍后面的两个:

$forceUpdate

调用强制更新方法this.$forceUpdate()会更新视图和数据,触发updated生命周期,


export default {
  methods: {
    handleUpdateClick() {
      // built-in
      this.$forceUpdate()
    }
  },
   updated(){
        console.log('更新了')
    }
}

key-changing

原理很简单,vue使用key标记组件身份,当key改变时就是释放原始组件,重新加载新的组件。

<template>
  <div>
    <span :key="key"></span>
  </div>
</template>
<script>
  export default {
    data() {
      return {
        key: 0
      }
    },
    methods: {
      handleUpdateClick() {
        this.key += 1 
      }
    }
  }
</script>

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值