解决vue router组件状态刷新消失的问题


Posted in Javascript onAugust 01, 2018

场景:vue-router实现的单页应用,登录页调用登录接口后,服务器返回用户信息,然后通过router.push({name: 'index', params: res.data})跳转到主页,并在主页显示数据。但是当刷新页面时,由于并不是通过登录接口进入主页,router中没有‘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钩子中调用登录接口来返回数据。

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

3、cookie

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

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

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存储到本地,为什么不直接把常用的数据直接保存到本地呢?利用本地数据,可以减少客户端网络请求,还可以降低服务器负担。

由于sessionStorage中保存的值是字符串,直接赋值非字符串类型会先调用其toString()方法。例如执行sessionStorage.user = user,保存的值却是[object Object]。我们可以通过JSON.stringify()将需要保存的对象转为JSON字符串再保存到sessionStorage,然后在需要使用时通过JSON.parse()将字符串转回对象。

let user = {
 name: 'admin',
 address: 'xxx',
 email: 'xx@xx.xx'
}
// sessionStorage.user = user // [object Object]
sessionStorage.user = JSON.stringify(user)
...
let data = JSON.parse(sessionStorage.user)

总结

以上所述是小编给大家介绍的解决vue router组件状态刷新消失的问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery 自定义函数写法分享
Mar 30 Javascript
我的Node.js学习之路(三)--node.js作用、回调、同步和异步代码 以及事件循环
Jul 06 Javascript
JQuery做的一个简单的点灯游戏分享
Jul 16 Javascript
Windows 系统下安装和部署Egret的开发环境
Jul 31 Javascript
javascript最基本的函数汇总
Jun 25 Javascript
常见的javascript跨域通信方法
Dec 31 Javascript
JavaScript 基础函数_深入剖析变量和作用域
May 18 Javascript
Html5 js实现手风琴效果
Apr 17 Javascript
Angular实现下载安装包的功能代码分享
Sep 05 Javascript
jQuery实现的上传图片本地预览效果简单示例
Mar 29 jQuery
nuxt框架中对vuex进行模块化设置的实现方法
Sep 06 Javascript
vant-ui框架的一个bug(解决切换后onload不触发)
Nov 11 Javascript
Promise.all中对于reject的处理方法
Aug 01 #Javascript
详解es6超好用的语法糖Decorator
Aug 01 #Javascript
Vue Router去掉url中默认的锚点#
Aug 01 #Javascript
vue定义全局变量和全局方法的方法示例
Aug 01 #Javascript
node.js遍历目录的方法示例
Aug 01 #Javascript
深入浅出理解JavaScript闭包的功能与用法
Aug 01 #Javascript
Angular路由ui-router配置详解
Aug 01 #Javascript
You might like
mysql5的sql文件导入到mysql4的方法
2008/10/19 PHP
并发下常见的加锁及锁的PHP具体实现代码
2010/10/12 PHP
php中使用Akismet防止垃圾评论的代码
2011/06/10 PHP
简单的php数据库操作类代码(增,删,改,查)
2013/04/08 PHP
Drupal读取Excel并导入数据库实例
2014/03/02 PHP
PHP实现图片上传并压缩
2015/12/22 PHP
PHP面向对象中new self()与 new static()的区别浅析
2017/08/17 PHP
php JWT在web端中的使用方法教程
2018/09/06 PHP
PHP实现SMTP邮件的发送实例
2018/09/27 PHP
对JavaScript的eval()中使用函数的进一步讨论
2008/07/26 Javascript
自己封装的javascript事件队列函数版
2014/06/12 Javascript
javascript常用代码段搜集
2014/12/04 Javascript
JavaScript如何自定义trim方法
2015/07/28 Javascript
详解JavaScript节流函数中的Throttle
2016/07/16 Javascript
AngularJS基础 ng-keypress 指令简单示例
2016/08/02 Javascript
浅析JavaScript动画模拟拖拽原理
2016/12/09 Javascript
js实现拖拽上传图片功能
2017/08/01 Javascript
vue和H5 draggable实现拖拽并替换效果
2020/07/29 Javascript
微信小程序实现购物车功能
2020/11/18 Javascript
[01:02:10]DOTA2上海特级锦标赛B组小组赛#2 VG VS Fnatic第一局
2016/02/26 DOTA
Python实现竖排打印传单手机号码易撕条
2015/03/16 Python
python使用webbrowser浏览指定url的方法
2015/04/04 Python
Python实现统计给定列表中指定数字出现次数的方法
2018/04/11 Python
Python八大常见排序算法定义、实现及时间消耗效率分析
2018/04/27 Python
Python中GIL的使用详解
2018/10/03 Python
浅谈Python脚本开头及导包注释自动添加方法
2018/10/27 Python
python之随机数函数的实现示例
2020/12/30 Python
简单掌握CSS3将文字描边及填充文字颜色的方法
2016/03/07 HTML / CSS
CSS3教程(10):CSS3 HSL声明设置颜色
2009/04/02 HTML / CSS
AmazeUI 折叠面板的实现代码
2020/08/17 HTML / CSS
iKRIX意大利网上商店:男女豪华服装和配件
2019/10/09 全球购物
中专毕业生的自荐书
2014/07/01 职场文书
幼儿园国庆节活动总结
2015/03/23 职场文书
公司行政主管岗位职责
2015/04/09 职场文书
GO语言字符串处理函数之处理Strings包
2022/04/14 Golang
MySQL串行化隔离级别(间隙锁实现)
2022/06/16 MySQL