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打开其他项目页面并传入数据详解
Nov 25 Vue.js
在vue项目中封装echarts的步骤
Dec 25 Vue.js
vue+element UI实现树形表格
Dec 29 Vue.js
vue 动态创建组件的两种方法
Dec 31 Vue.js
如何在vue中使用HTML 5 拖放API
Jan 14 Vue.js
vue实现轮播图帧率播放
Jan 26 Vue.js
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
Vue3 Composition API的使用简介
Mar 29 Vue.js
原生JS封装vue Tab切换效果
Apr 28 Vue.js
vue-cropper插件实现图片截取上传组件封装
May 27 Vue.js
Vue2.0搭建脚手架
Mar 13 Vue.js
vue组件vue-esign实现电子签名
Apr 21 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
15种PHP Encoder的比较
2007/04/17 PHP
php中获取远程客户端的真实ip地址的方法
2011/08/03 PHP
CI框架学习笔记(一) - 环境安装、基本术语和框架流程
2014/10/26 PHP
ThinkPHP中redirect用法分析
2014/12/05 PHP
smarty模板判断数组为空的方法
2015/06/10 PHP
详解PHP对象的串行化与反串行化
2016/01/24 PHP
JavaScript 三种创建对象的方法
2009/10/16 Javascript
JQuery的Ajax请求实现局部刷新的简单实例
2014/02/11 Javascript
JavaScript调用浏览器打印功能实例分析
2015/07/17 Javascript
JS中创建函数的三种方式及区别
2016/03/13 Javascript
js实现一个猜数字游戏
2017/03/31 Javascript
AngularJS实现单一页面内设置跳转路由的方法
2017/06/28 Javascript
weex slider实现滑动底部导航功能
2017/08/28 Javascript
新手入门带你学习JavaScript引擎运行原理
2019/06/24 Javascript
vue-cli点击实现全屏功能
2020/03/07 Javascript
Vue2.0 $set()的正确使用详解
2020/07/28 Javascript
javascript canvas实现简易时钟例子
2020/09/05 Javascript
python装饰器decorator介绍
2014/11/21 Python
Python利用IPython提高开发效率
2016/08/10 Python
Python numpy 提取矩阵的某一行或某一列的实例
2018/04/03 Python
Python hashlib模块用法实例分析
2018/06/12 Python
pandas通过索引进行排序的示例
2018/11/16 Python
对python操作kafka写入json数据的简单demo分享
2018/12/27 Python
Python动态语言与鸭子类型详解
2019/07/01 Python
postman模拟访问具有Session的post请求方法
2019/07/15 Python
详解Python中字符串前“b”,“r”,“u”,“f”的作用
2019/12/18 Python
浅谈Python中的异常和JSON读写数据的实现
2020/02/27 Python
Python ConfigParser模块的使用示例
2020/10/12 Python
世界上第一个创建了罩杯系统的美国内衣品牌:Maidenform
2019/03/23 全球购物
寄语十八大感言
2014/02/07 职场文书
学校安全生产月活动总结
2014/07/05 职场文书
群众路线教育实践活动心得体会(教师)
2014/10/31 职场文书
收银员岗位职责
2015/02/03 职场文书
信用卡催款律师函
2015/05/27 职场文书
运动会新闻报道稿
2015/07/22 职场文书
2016年区委书记抓基层党建工作公开承诺书
2016/03/25 职场文书