Vue 路由切换时页面刷新页面

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

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

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

解决办法:

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


  • 列表页面被缓存 第二次返回详情页面数据还显示上一次编辑时保存的数据,actived钩子里面重新调用一下获取详情的方法
  • 页面第一次进来时生命周期执行顺序 create mounted actived
  • 第二次进来只执行actived钩子

Vue 路由切换时页面刷新页面_第1张图片 

Vue 路由切换时页面刷新页面_第2张图片

 

你可能感兴趣的:(vue)