vue 强制刷新组件
使用vue进行开发时,如果要刷新当前路由,则调用router.go(0)方法即可。但是某些情况下,我们可能要求仅仅刷新某个组件,而不是路由,那么我们应该怎么做呢?1.使用this.forceUpdate强制重新渲染如果要在组件内部中进行强制刷新,则可以调用this.forceUpdate强制重新渲染如果要在组件内部中进行强制刷新,则可以调用this.forceUpdate强制重新渲染如果要在组件内
使用vue进行开发时,如果要刷新当前路由,则调用router.go(0)方法即可。但是某些情况下,我们可能要求仅仅刷新某个组件,而不是路由,那么我们应该怎么做呢?
1.使用this.
f
o
r
c
e
U
p
d
a
t
e
强
制
重
新
渲
染
如
果
要
在
组
件
内
部
中
进
行
强
制
刷
新
,
则
可
以
调
用
t
h
i
s
.
forceUpdate强制重新渲染 如果要在组件内部中进行强制刷新,则可以调用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>
更多推荐
所有评论(0)