vue路由跳转数据不更新解决

第二次进入页面,页面路由参数已经改变,但是页面内容不会刷新。

问题原因:在组件mounted钩子中调用的刷新页面内容,但测试发现这个钩子没有被调用。后来发现App.vue中使用了<keep-alive>:

<template>
    <div id="app">

        <keep-alive>

            <router-view></router-view>

        </keep-alive>

    </div>

</template>
keep-alive是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM。这就是问题所在了。

解决办法:

使用Vue组件切换过程钩子activated(keep-alive组件激活时调用),而不是挂载钩子mounted:

<script>

export default {

  // ...

activated: function() {

    this.getCase()

    }

}

</script>

转自:https://blog.csdn.net/z9061/article/details/82179988

猜你喜欢

转载自blog.csdn.net/qq_40934679/article/details/85178384