vue-router路由参数刷新消失的问题解决方法


Posted in Javascript onJune 17, 2017

场景:vue-router实现的单页应用,登录页调用登录接口后,服务器返回用户信息,然后通过router.push({name: 'index', params: res.data})传给主页组件,并在主页显示数据。但是刷新页面后,数据就消失了。

解决方案:

1、session&服务器渲染

传统的方案是,登录页和主页是单独的两个页面,登录成功后服务器生成用户信息对应的session,然后渲染主页数据,并通过响应头将sessionid传给浏览器并生成相应的cookie文件。这样下次请求页面时,浏览器会在http header带上相应的cookie,然后服务器根据cookie中的sessionid判断用户是否登录,再显示用户数据。
 如果项目采用前后端分离思想,服务器只提供接口,不进行服务器渲染,那么这种办法是行不通了。

2、$route.query

我们可以在路由跳转的时候带上登录请求的参数:

router.push({name:'index', query:{username: 'xxx', password: 'xxxxxx'}})
...
this.$ajax({
 url: 'xxx',
 method: 'post',
 data: {
  username: this.$route.query.username,
  password: this.$route.query.password
 }
})

这样登录参数会被保存在url中,像这样:“http://xxx.xxx.xxx/index?username=xxx&password=xxxxxx”,然后在created钩子中调用登录接口来返回数据。

即使密码进行了md5加密,将用户名密码这类敏感信息放在url中肯定也是不合理。

3、cookie

另一个办法是把登录参数存入cookie,然后在created钩子中获取cookie中存的信息,再调用登录接口。将用户名密码存入cookie中同样不合理,改进版是登录成功后服务器返回一个token,在有效期内通过token获取用户数据。

cookie存取数据比较麻烦,因为cookie中键值对是字符串并以 "=" 链接,需要额外写操作cookie的方法。

<script>
 function setCookie (name, value, exdays) {
  let date = new Date()
  date.setTime(date.getTime() + (exdays * 24 * 60 * 60 * 1000))
  let expires = "expires=" + date.toGMTString()
  document.cookie = name + "=" + value + "; " + expires
 }
 function getCookie (name) {
  name = name + "="
  let cookieArr = document.cookie.split(';')
  for (let i = 0; i < cookieArr.length; i++) {
   let cookie = cookieArr[i].trim()
   if (cookie.indexOf(name) === 0) {
    return cookie.slice(name.length)
   }
  }
  return ""
 }

4、HTML5 Web存储

提到Web存储,潜意识肯定觉得很多浏览器都不支持,其实IE8及以上都支持localStorage和sessionStorage了。Vue项目最低支持IE9,所以可以放心的使用Web存储。

localStorage存储数据没有时间限制,不主动删除就不会失效。而sessionStorage是在页面或者浏览器关闭时就会失效,适合本场景应用。

我们可以把token信息存在sessionStorage中,然后每次刷新页面通过token请求数据;但是既然能够把token存储到本地,为什么不直接把常用的数据直接保存到本地呢?利用本地数据,可以减少客户端网络请求,还可以降低服务器负担。

由于localStorage和sessionStorage是只读的,不能直接将其指向一个对象。也不能利用Object.assign()复制对象,因为值会变成字符串"[object Object]",所有只有通过循环为 sessionStorage 添加属性了。

...
for (var key in res.data.customer) {
 sessionStorage[key] = res.data.customer[key]
} 
...

以上是我在最近工作中遇到的问题,最后采用的方案是使用sessionStorage存储数据。

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

Javascript 相关文章推荐
jQuery getJSON()+.ashx 实现分页(改进版)
Mar 28 Javascript
中文字符串截取的js函数代码
Apr 17 Javascript
如何学习Javascript入门指导
Nov 01 Javascript
浅析JavaScript中两种类型的全局对象/函数
Dec 05 Javascript
jQuery常用数据处理方法小结
Feb 20 Javascript
javascript+ajax实现产品页面加载信息
Jul 09 Javascript
JS实现仿新浪微博发布内容为空时提示功能代码
Aug 19 Javascript
JSON 的正确用法探讨:Pyhong、MongoDB、JavaScript与Ajax
May 15 Javascript
Vue.js实现多条件筛选、搜索、排序及分页的表格功能
Nov 24 Javascript
JS解决position:sticky的兼容性问题的方法
Oct 17 Javascript
layui监听select变化,以及设置radio选中的方法
Sep 24 Javascript
微信小程序利用云函数获取手机号码
Dec 17 Javascript
JS实现商品筛选功能
Aug 19 #Javascript
node文件上传功能简易实现代码
Jun 16 #Javascript
详解webpack 多入口配置
Jun 16 #Javascript
requirejs + vue 项目搭建详解
Jun 16 #Javascript
jQuery 控制文本框自动缩小字体填充
Jun 16 #jQuery
jQuery序列化后的表单值转换成Json
Jun 16 #jQuery
详解探索 vuex 2.0 以及使用 vuejs 2.0 + vuex 2.0 构建记事本应用
Jun 16 #Javascript
You might like
提升PHP执行速度全攻略(上)
2006/10/09 PHP
PHP 的ArrayAccess接口 像数组一样来访问你的PHP对象
2010/10/12 PHP
在PHP中设置、使用、删除Cookie的解决方法
2013/05/06 PHP
php实现阿拉伯数字和罗马数字相互转换的方法
2015/04/17 PHP
深入理解PHP内核(一)
2015/11/10 PHP
Laravel+jQuery实现AJAX分页效果
2016/09/14 PHP
js模拟弹出效果代码修正版
2008/08/07 Javascript
javascript实现的像java、c#之类的sleep暂停的函数代码
2010/03/04 Javascript
Javascript设置对象的ReadOnly属性(示例代码)
2013/12/25 Javascript
jQuery元素的隐藏与显示实例
2015/01/20 Javascript
js+CSS实现弹出居中背景半透明div层的方法
2015/02/26 Javascript
分享有关jQuery中animate、slide、fade等动画的连续触发、滞后反复执行的bug
2016/01/10 Javascript
vue初尝试--项目结构(推荐)
2018/01/30 Javascript
React 组件中的 bind(this)示例代码
2018/09/16 Javascript
Vue实现拖放排序功能的实例代码
2019/07/08 Javascript
npm qs模块使用详解
2020/02/07 Javascript
JS代码实现页面切换效果
2021/01/10 Javascript
Python中处理字符串之endswith()方法的使用简介
2015/05/18 Python
详解Python中的四种队列
2018/05/21 Python
python3 flask实现文件上传功能
2020/03/20 Python
Python实现Selenium自动化Page模式
2019/07/14 Python
Python学习笔记之文件的读写操作实例分析
2019/08/07 Python
python opencv将表格图片按照表格框线分割和识别
2019/10/30 Python
Python使用Pygame绘制时钟
2020/11/29 Python
使用html5+css3来实现slider切换效果告别javascript+css
2013/01/08 HTML / CSS
Supersmart英国:欧洲市场首批食品补充剂供应商之一
2018/05/05 全球购物
致铅球运动员广播稿精选
2014/01/12 职场文书
少先队学雷锋活动总结范文
2014/03/09 职场文书
高等学院职业生涯规划书范文
2014/09/16 职场文书
推广普通话共筑中国梦演讲稿
2014/09/21 职场文书
通报表扬范文
2015/01/17 职场文书
2015幼儿园新学期寄语
2015/02/27 职场文书
安全保证书怎么写
2015/02/28 职场文书
高一军训感想
2015/08/07 职场文书
装修安全责任协议书
2016/03/22 职场文书
Python 读写 Matlab Mat 格式数据的操作
2021/05/19 Python