vue---强制刷新子组件重新渲染

1,在父组件中,给子组件添加v-if属性

<Button v-if="refresh" :data='data' />

2,监听data,当data发生变化时,重新渲染子组件
提示:这个方法会强制删除旧组件并创建新组件。

export default {
	data(){
		data: [],
		refresh: true
	},
	watch:{
		data(){
			this.refresh = false;
			this.$nextTick(() => {
		        // 重新渲染组件
		    	this.refresh = true;
		    });
		}
	}
}

3,较好的方式:forceUpdate
提示:这不会更新任何计算属性,调用forceUpdate仅仅强制重新渲染视图。

// 全局
import Vue from 'vue';
Vue.forceUpdate();

// 使用组件实例
export default {
  methods: {
    methodThatForcesUpdate() {
      // ...
      this.$forceUpdate();
      // ...
    }
  }
}

4,最好的方法:key
如果key保持不变,则不会更改组件,但当key发生更改时,vue会删除旧组件并创建新组件,它将重新初始化自身并“重置”其状态
提示:如果确实需要重新渲染某些内容,请选择key更改方法而不是其他方法。

<template>
  <component-to-re-render :key="componentKey" />
</template>


export default {
  data() {
    return {
      componentKey: 0,
    };
  },
  methods: {
    forceRerender() {
      this.componentKey += 1;  
    }
  }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值