vue中强制刷新$forceUpdate的使用

Home / Article MrLee 2021-1-8 2043

类型:vue

需求:页面上一个固定长度数组,数组每个元素绑定不同组件,显示内容不定期刷新

问题:vue目前监测方法是对象属性是否改变,对于数组,如果长度未发生变化是不会刷新数据的,也就是说,数组里面的任何一个成员属性发生改变,我们在UI上是看不出来的,为了使UI刷新,当时想的方法是在v-for外层的div添加了一个itemprop属性,然后将这个绑定一个text字符串,每次要刷新就更新这个text即可。效果还是没问题,但是今天看文章,偶然发现VUE自带强制刷新方法,如标题this.$forceUpdate会重新渲染整个ui,之前百度搜索可能关键字不太对!

下面提供2个刷新解决方案

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

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

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

2.使用v-if指令

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

刷新组件的目的。

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

本文链接:https://www.it72.com/12674.htm

推荐阅读
最新回复 (0)
返回