Vue router传递参数并解决刷新页面参数丢失问题


Posted in Vue.js onDecember 02, 2020

Vue Router 传参方式:

1. this.$router.push({ name: '模块名称', params: { // 各参数 } })

router.js:

export default new Router({
 routes: [
  {
   path: '/paramsPassingByRouter',
   component: ParamsPassingByRouter,
   children: [
    {
     path: 'paramsMode',
     name: 'paramsMode',
     component: ParamsMode
    }
   ]
  }
 ]
})

ParamsPassingByRouter.vue:

<!-- html -->
<button @click="paramsMode(testData)">params传参</button>

<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {
    id: '20180101',
    name: '张三',
    aka: 'z3',
    age: '18'
   }
  }
 },
 methods: {
  paramsMode (data) {
   this.$router.push({
    name: 'paramsMode',
    params: data
   })
  }
 }
}
</script>

ParamsMode.vue:

<!-- html -->
<div class="params-mode">{{ testData }}</div>

<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {}
  }
 },
 created () {
  this.testData = this.$route.params
 }
}
</script>

效果:
url:http://localhost:8081/#/paramsPassingByRouter/paramsMode
页面显示:{"id":"20180101","name":"张三","aka":"z3","age":"18"}

但是刷新页面后,数据会丢失,显示:{}。

2. this.$router.push({ name: '模块名称', query: { // 各参数 } })

router.js:

export default new Router({
 routes: [
  {
   path: '/paramsPassingByRouter',
   component: ParamsPassingByRouter,
   children: [
    {
     path: 'queryMode',
     name: 'queryMode',
     component: QueryMode
    }
   ]
  }
 ]
})

ParamsPassingByRouter.vue:

<!-- html -->
<button @click="queryMode(testData)">query传参</button>

<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {
    id: '20180101',
    name: '张三',
    aka: 'z3',
    age: '18'
   }
  }
 },
 methods: {
  queryMode (data) {
   this.$router.push({
    name: 'paramsMode',
    query: data
   })
  }
 }
}
</script>

QueryMode.vue:

<!-- html -->
<div class="query-mode">{{ testData }}</div>

<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {}
  }
 },
 created () {
  this.testData = this.$route.query
 }
}
</script>

效果:
url:http://localhost:8081/#/paramsPassingByRouter/queryMode?id=20180101&name=%E5%BC%A0%E4%B8%89&aka=z3&age=18
页面显示:{"id":"20180101","name":"张三","aka":"z3","age":"18"}

刷新页面后,数据不会丢失。

解决刷新页面数据丢失的方案:

使用 this.$router.push({ name: '模块名称', query: { // 各参数 } }) 方式传参。

缺点:参数值都拼接在 url 上,url 会很长,同时都可被看到。

this.$router.push({ name: '模块名称', params: { // 各参数 } }) 路由文件设置的时候把参数拼到 url 里。

url:http://localhost:8081/#/paramsPassingByRouter/paramsMode/20180101/%E5%BC%A0%E4%B8%89/z3/18
缺点:同上。

1 和 2 结合使用:this.$router.push({ name: '模块名称', params: { // 各参数 }, query: { // 各参数 } })。

老老实实的用 localStorage 存储。

url: http://localhost:8081/#/paramsPassingByRouter/paramsMode/z3
可以与 params 和 query 方式配合使用,可以暴露的参数显示在 url 上,同时刷新参数也不会丢失。
销毁页面的时候把 localStorage 存储的内容清除。

// router.js
{
 path: 'paramsMode/:aka',
 name: 'paramsMode',
 component: ParamsMode
}

<!-- ParamsMode.vue 修改 -->
<script>
export default {
 data () {
  return {
   testData: {}
  }
 },
 created () {
  const tempData = localStorage.getItem('tempData')
  if (tempData) {
   this.testData = JSON.parse(tempData)
  } else {
   this.testData = this.$route.params

   localStorage.setItem('tempData', JSON.stringify(this.$route.params))
  }
 },
 beforeDestroy () {
  localStorage.removeItem('tempData')
 }
}
</script>

到此这篇关于Vue router传递参数并解决刷新页面参数丢失问题的文章就介绍到这了,更多相关Vue router传递参数丢失内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
vue调用微信JSDK 扫一扫,相册等需要注意的事项
Jan 03 Vue.js
如何在vue-cli中使用css-loader实现css module
Jan 07 Vue.js
vue 递归组件的简单使用示例
Jan 14 Vue.js
vue+echarts实现中国地图流动效果(步骤详解)
Jan 27 Vue.js
vue 实现click同时传入事件对象和自定义参数
Jan 29 Vue.js
vue实现拖拽进度条
Mar 01 Vue.js
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 Vue.js
Vue.js中v-bind指令的用法介绍
Mar 13 Vue.js
一起来看看Vue的核心原理剖析
Mar 24 Vue.js
Vue+Flask实现图片传输功能
Apr 01 Vue.js
vue选项卡切换的实现案例
Apr 11 Vue.js
Vue操作Storage本地化存储
Apr 29 Vue.js
详解Vue3 Teleport 的实践及原理
Dec 02 #Vue.js
vue $router和$route的区别详解
Dec 02 #Vue.js
基于vue项目设置resolves.alias: '@'路径并适配webstorm
Dec 02 #Vue.js
element-plus一个vue3.xUI框架(element-ui的3.x 版初体验)
Dec 02 #Vue.js
vue组件中节流函数的失效的原因和解决方法
Dec 02 #Vue.js
Vue3+elementui plus创建项目的方法
Dec 01 #Vue.js
Vue.js桌面端自定义滚动条组件之美化滚动条VScroll
Dec 01 #Vue.js
You might like
10个可以简化php开发过程的MySQL工具
2010/04/11 PHP
php时区转换转换函数
2014/01/07 PHP
js简单实现根据身份证号码识别性别年龄生日
2013/11/29 Javascript
js控制input输入字符解析
2013/12/27 Javascript
Node.js开发之访问Redis数据库教程
2015/01/14 Javascript
jQuery通过写入cookie实现更换网页背景的方法
2016/04/15 Javascript
jQuery Easyui学习教程之实现datagrid在没有数据时显示相关提示内容
2016/07/09 Javascript
Backbone View 之间通信的三种方式
2016/08/09 Javascript
第一次接触Bootstrap框架
2016/10/24 Javascript
vue父组件向子组件动态传值的两种方法
2017/11/11 Javascript
vue-router跳转时打开新页面的两种方法
2019/07/29 Javascript
Javascript和jquery在selenium的使用过程
2019/10/31 jQuery
vuex实现购物车功能
2020/06/28 Javascript
js实现磁性吸附的示例
2020/10/26 Javascript
[01:54]胎教DOTA2 准妈妈玩家现身中国区预选赛
2016/06/26 DOTA
Python函数参数类型*、**的区别
2015/04/11 Python
django实现用户登陆功能详解
2017/12/11 Python
Python数据结构与算法之字典树实现方法示例
2017/12/13 Python
Python打开文件,将list、numpy数组内容写入txt文件中的方法
2018/10/26 Python
python提取xml里面的链接源码详解
2019/10/15 Python
Python写出新冠状病毒确诊人数地图的方法
2020/02/12 Python
python实现横向拼接图片
2020/03/23 Python
Dr. Martens马汀博士官网:马丁靴始祖品牌
2016/10/15 全球购物
3分钟演讲稿
2014/04/30 职场文书
电子商务专业应届生求职信
2014/05/28 职场文书
2014大学校园光棍节活动策划书
2014/09/29 职场文书
教师对照四风自我剖析材料
2014/09/30 职场文书
领导干部作风整顿剖析材料
2014/10/11 职场文书
2015政治思想表现评语
2015/03/25 职场文书
2015年房产销售工作总结范文
2015/05/22 职场文书
少先队中队工作总结
2015/08/14 职场文书
2016年端午节寄语
2015/12/04 职场文书
写作技巧:怎样写好一份优秀工作总结?
2019/08/14 职场文书
python tkinter实现定时关机
2021/04/21 Python
Python利用机器学习算法实现垃圾邮件的识别
2021/06/28 Python
Python面试不修改数组找出重复的数字
2022/05/20 Python