vue 强制刷新组件

vue 强制刷新组件

使用vue进行开发时,如果要刷新当前路由,则调用router.go(0)方法即可。但是某些情况下,我们可能要求仅仅刷新某个组件,而不是路由,那么我们应该怎么做呢?

1.使用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><compv-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>

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在项目中会有一种场景,例如:在酒店详情页面中,最下面有一个推荐类似酒店的列表,此时点击之后业务逻辑依然是当前页面,...
    哟西大人1阅读 869评论 1 1
  • 使用vue进行开发时,如果要刷新当前路由,则调用router.go(0)方法即可。但是某些情况下,我们可能要求仅仅...
    我啊翔1314阅读 134,326评论 1 19
  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,268评论 0 6
  • 以下内容是我在学习和研究Vue时,对Vue的特性、重点和注意事项的提取、精练和总结,可以做为Vue特性的字典; 1...
    科研者阅读 14,171评论 3 24
  • 基础知识: vue的生命周期:beforeCreate/created、beforeMount/mounted、b...
    rightmost阅读 577评论 0 0