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 相关文章推荐
Vue3+elementui plus创建项目的方法
Dec 01 Vue.js
vue3.0+vue-router+element-plus初实践
Dec 02 Vue.js
vue从后台渲染文章列表以及根据id跳转文章详情详解
Dec 14 Vue.js
vue项目中企业微信使用js-sdk时config和agentConfig配置方式详解
Dec 15 Vue.js
vuex的使用步骤
Jan 06 Vue.js
Vite和Vue CLI的优劣
Jan 30 Vue.js
如何使用vue3打造一个物料库
May 08 Vue.js
Vue详细的入门笔记
May 10 Vue.js
详解Vue的sync修饰符
May 15 Vue.js
vue3使用vue-router的完整步骤记录
Jun 20 Vue.js
Vue + iView实现Excel上传功能的完整代码
Jun 22 Vue.js
vue代码分块和懒加载非必要资源文件
Apr 11 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
PHP+Mysql日期时间如何转换(UNIX时间戳和格式化日期)
2012/07/15 PHP
php用户注册时常用的检验函数实例总结
2014/12/22 PHP
[原创]php正则删除html代码中class样式属性的方法
2017/05/24 PHP
laravel框架邮箱认证实现方法详解
2019/11/22 PHP
如何在PHP中读写文件
2020/09/07 PHP
理解 JavaScript 预解析
2009/10/25 Javascript
网页图片延时加载的js代码
2010/04/22 Javascript
Web开发者必备的12款超赞jQuery插件
2010/12/03 Javascript
也说JavaScript中String类的replace函数
2011/09/22 Javascript
jquery选择器之层级过滤选择器详解
2014/01/27 Javascript
PHP守护进程实例
2015/03/06 Javascript
百度地图API之本地搜索与范围搜索
2015/07/30 Javascript
jQuery实现可拖动进度条实例代码
2017/06/21 jQuery
微信小程序 按钮滑动的实现方法
2017/09/27 Javascript
BootStrap TreeView使用实例详解
2017/11/01 Javascript
vue-cli+webpack项目 修改项目名称的方法
2018/02/28 Javascript
教你30秒发布一个TypeScript包到NPM的方法步骤
2019/07/22 Javascript
vue 设置 input 为不可以编辑的实现方法
2019/09/19 Javascript
jquery实现商品sku多属性选择功能(商品详情页)
2019/12/20 jQuery
简单了解常用的JavaScript 库
2020/07/16 Javascript
在Python的Flask框架下使用sqlalchemy库的简单教程
2015/04/09 Python
树莓派动作捕捉抓拍存储图像脚本
2019/06/22 Python
Pycharm远程调试原理及具体配置详解
2019/08/08 Python
通过python扫描二维码/条形码并打印数据
2019/11/14 Python
keras 如何保存最佳的训练模型
2020/05/25 Python
Ticketmaster德国票务网站:购买音乐会和体育等门票
2016/11/14 全球购物
您在慕尼黑的跑步商店:Lauf-bar
2019/10/11 全球购物
一套Java笔试题
2016/08/20 面试题
大学生职业生涯规划书前言
2014/01/09 职场文书
大学生素质拓展活动方案
2014/02/11 职场文书
保护野生动物倡议书
2014/05/16 职场文书
女性健康知识讲座通知
2015/04/23 职场文书
毕业酒会致辞
2015/07/29 职场文书
学生病假条范文
2015/08/17 职场文书
MySQL 覆盖索引的优点
2021/05/19 MySQL
Java实现多文件上传功能
2021/06/30 Java/Android