Vue 路由切换时页面内容没有从新加载

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

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

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

解决办法:测试

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

<script>
export default {
  // ...
  activated: function() {
    this.getCase()
  }
}
</script>
关于keep-alive组件的钩子:https://cn.vuejs.org/v2/api/#activated.net


--------------------- 
做者:木马啊 
来源:CSDN 
原文:https://blog.csdn.net/u010419337/article/details/79443360 
版权声明:本文为博主原创文章,转载请附上博文连接!router

相关文章
相关标签/搜索