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


Posted in Javascript onOctober 08, 2019

最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决;Vue中给我们提供了三种路由传参方式,下面我们一个一个的来看一下:

方法一:params传参:

this.$router.push({
    name:"admin",

//这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或者Vue实例上直接取)
    params:{id:item.id}
})    

//这个组件对应的路由配置
{

//组件路径
  path: '/admin',

//组件别名
  name: 'admin',

//组件名
  component: Admin,
}

通过params传递参数,如果我们想获取id的 参数值,我们可以通过this.$route.params.id这种方式来打印出来就可以得到了;(注意:获取参数的时候是$route,跳转和传参的时候是$router)

方法二:路由属性配置传参:

this.$router.push({
    name:"/admin/${item.id}",
})    

//这个组件对应的路由配置
{
//组件路径
  path: '/admin:id',

//组件别名
  name: 'admin',

//组件名
  component: Admin,
}

通过路由属性配置传参我们可以用this.$route.params.id来获取到id的值,注意this.$router.push方法里面路径带的是值,路由配置项那里带的是变量名(属性名)来实现的对应;

以上两种传参方式基本上可以理解为ajax中的post请求方式,参数都是不可见的,但是上面两种方法都有一个弊端,就是当页面刷新了是获取不到参数值的,那么有没有一种方法是页面刷新之后参数依然存在呢?

方法三:query传参

this.$router.push({
    name:"/admin",

 query:{id:item.id}
})    
//这个组件对应的路由配置
{

//组件路径
  path: '/admin',

//组件别名
  name: 'admin',

//组件名
  component: Admin,
}

第三种方式是用query来传参,这种方式是可以解决页面刷新参数消失问题的,这种方式可以理解为是ajax中的get方法,参数是直接在url后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用方法三来解决;

其实解决页面刷新参数丢失问题的方案还有很多,比如把参数存在sessionStorange或者localStorange中都是可行的,不过我们既然用vue框架,就要用vue的方式来解决问题。这里只是想告诉大家,问题的解决方案可以多种多样,要学会用多种方式或者说多种方案来解决一个问题,不要有太多的局限性!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
在网页里看flash的trace数据的js类
Jan 10 Javascript
jqueyr判断checkbox组的选中(示例代码)
Nov 08 Javascript
jquery防止重复执行动画避免页面混乱
Apr 22 Javascript
JavaScript判断前缀、后缀是否是空格的方法
Apr 15 Javascript
jQuery ajax全局函数处理session过期后的ajax跳转问题
Jun 03 Javascript
基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询
Oct 30 Javascript
jsp 自动编译机制详细介绍
Dec 01 Javascript
js中作用域的实例解析
Mar 16 Javascript
layui分页效果实现代码
May 19 Javascript
JS实现unicode和UTF-8之间的互相转换互转
Jul 05 Javascript
jquery手机触屏滑动拼音字母城市选择器的实例代码
Dec 11 jQuery
详解vue项目打包后通过百度的BAE发布到网上的流程
Mar 05 Javascript
vux-scroller实现移动端上拉加载功能过程解析
Oct 08 #Javascript
深入学习Vue nextTick的用法及原理
Oct 08 #Javascript
jQuery 筛选器简单操作示例
Oct 02 #jQuery
jQuery 查找元素操作实例小结
Oct 02 #jQuery
JavaScript 作用域实例分析
Oct 02 #Javascript
JavaScript Dom 绑定事件操作实例详解
Oct 02 #Javascript
JavaScript 面向对象基础简单示例
Oct 02 #Javascript
You might like
php生成EXCEL的东东
2006/10/09 PHP
基于PHP读取TXT文件向数据库导入海量数据的方法
2013/04/23 PHP
PHPThumb图片处理实例
2014/05/03 PHP
php阿拉伯数字转中文人民币大写
2015/12/21 PHP
JS 屏蔽按键效果与改变按键效果的示例代码
2013/12/24 Javascript
jquery 实现输入邮箱时自动补全下拉提示功能
2015/10/04 Javascript
利用Node.js编写跨平台的spawn语句详解
2017/02/12 Javascript
ES6新数据结构Map功能与用法示例
2017/03/31 Javascript
vue-cli构建项目下使用微信分享功能
2018/05/28 Javascript
详解vue添加删除元素的方法
2018/06/30 Javascript
JS无限级导航菜单实现方法
2019/01/05 Javascript
javascript实现移动端轮播图
2020/12/09 Javascript
[06:42]DOTA2每周TOP10 精彩击杀集锦vol.1
2014/06/25 DOTA
[01:00:14]2018DOTA2亚洲邀请赛 4.6 淘汰赛 VP vs TNC 第三场
2018/04/10 DOTA
python基础教程之简单入门说明(变量和控制语言使用方法)
2014/03/25 Python
Pytorch修改ResNet模型全连接层进行直接训练实例
2019/09/10 Python
基于Python实现拆分和合并GIF动态图
2019/10/22 Python
对Pytorch中Tensor的各种池化操作解析
2020/01/03 Python
使用python 的matplotlib 画轨道实例
2020/01/19 Python
python+selenium定时爬取丁香园的新型冠状病毒数据并制作出类似的地图(部署到云服务器)
2020/02/09 Python
浅谈Python 参数与变量
2020/06/20 Python
美国迪克体育用品商店:DICK’S Sporting Goods
2018/07/24 全球购物
美国转售二手商品的电子商务平台:BLINQ
2018/12/13 全球购物
Groupon西班牙官方网站:在线优惠券和交易,节省高达70%
2021/03/13 全球购物
德国W家官网,可直邮中国的母婴商城:Windeln.de
2021/03/03 全球购物
入党自我鉴定范文
2013/10/04 职场文书
银行办理业务介绍信
2014/01/18 职场文书
家居饰品店创业计划书
2014/01/31 职场文书
移交协议书
2014/08/19 职场文书
2014年保险公司工作总结
2014/11/22 职场文书
给老婆的保证书
2015/01/16 职场文书
教师继续教育反思周记
2015/06/25 职场文书
七一表彰大会简报
2015/07/20 职场文书
会计实训总结范文
2015/08/03 职场文书
html+css 实现简易导航栏功能
2021/04/07 HTML / CSS
SQLServer之常用函数总结详解
2021/08/30 SQL Server