最后,这是强制Vue重新渲染组件的最佳方法(我认为)。
我们可以采用这种将key分配给子组件的策略,但是每次想重新渲染组件时,只需更新该key即可。
这是一个非常基本的方法
<template>
<component-to-re-render :key="componentKey" />
</template>
export default {
data() {
return {
componentKey: 0,
};
},
methods: {
forceRerender() {
this.componentKey += 1;
}
}
}
每次forceRerender被调用时,我们的componentKey都会改变。当这种情况发生时,Vue将知道它必须销毁组件并创建一个新组件。我们得到的是一个子组件,它将重新初始化自身并“重置”其状态。
如果确实需要重新渲染某些内容,请选择key更改方法而不是其他方法。