vue:解决使用param传参后,再次刷新页面会新增一个原有的tab

Posted 小飞猪咯咯

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue:解决使用param传参后,再次刷新页面会新增一个原有的tab相关的知识,希望对你有一定的参考价值。

问题:在最近的项目中,我通过传递不同的参数,复用同一组件进行渲染,然而意外出现一个bug,就是当我重新刷新该页面时,会新增一个tab

原来的:

 

刷新页面后:

 

 

 

查阅资料后,发现该现象是由于通过params进行传递的参数引起的,params进行传参后再次刷新页面,参数丢失,导致fullpath不一致,从而新增了页面(而我使用的d2admin基于element-ui第三方框架)

解决方案:将params方式传参改为使用query传参,这样参数就不会因为刷新而丢失

参考:

https://juejin.im/post/5c139fed6fb9a049ab0d80dc

query和params传参的区别?

  • query 传参配置的是path,而params传参配置的是name,在params中配置path无效
  • query在路由配置不需要设置参数,而params必须设置
  • query传递的参数会显示在地址栏中
  • params传参刷新会无效,但是query会保存传递过来的值,刷新不变 ;

 如果路由上面不写参数,也是可以传过去的,但不会在url上面显示出你的参数,并且当你跳到别的页面或者刷新页面的时候参数会丢失,那依赖这个参数的http请求或者其他操作就会失败

 

以上是关于vue:解决使用param传参后,再次刷新页面会新增一个原有的tab的主要内容,如果未能解决你的问题,请参考以下文章

vue:使用不同参数跳转同一组件,实现动态加载图片和数据,以及利用localStorage和vuex持久化数据

Vue路由传参及传参后刷新导致参数消失处理

Vue---传参params 、query刷新页面参数会丢失

vue路由传参页面刷新参数丢失问题解决方案

路由解耦-解决Vue通过name和params进行跳转页面传参刷新参数丢失的问题

vue param与query传参刷新数据消失处理