vue强制刷新组件

1.使用this.$forceUpdate强制重新渲染

如果要在组件内部中进行强制刷新,则可以调用this.forceUpdate强制重新渲染组件,从而达到更新目的。

<template>
     <button @click="reload()">刷新当前组件</button>
</template>
<script>
	export default {
	    name: 'mycom',
	    methods: {
	        reload() {
	            this.$forceUpdate()
	        }
	    }
	}
</script>

注意:forceUpdate 是迫使 Vue 实例重新渲染。注意它仅仅影响实例本身和插入插槽内容的子组件,而不是所有子组件。

2.使用v-if指令

如果是刷新某个子组件,则可以通过v-if指令实现。我们知道,当v-if的值发生变化时,组件都会被重新渲染一遍。因此,利用v-if指令的特性,可以达到强制
刷新组件的目的。

<template>
    <div>
        <mycom v-if="update"></mycom>
        <button @click="reload()">刷新comp组件</button>
    </div>
</template>
<script>
	import mycom from '@/views/mycom.vue'
	export default {
	    name: 'parentComp',
	    data() {
	        return {
	            update: true
	        }
	    },
	    methods: {
	        reload() {
	            // 移除组件
	            this.update = false
	            // 在组件移除后,重新渲染组件
	            // this.$nextTick可实现在DOM 状态更新后,执行传入的方法。
	            this.$nextTick(() => {
	                this.update = true
	            })
	        }
	    }
	}
</script>

发表评论

电子邮件地址不会被公开。 必填项已用*标注