详解Vuex管理登录状态


Posted in Javascript onNovember 13, 2017

又仔细看了一遍vuex的文档,还是云里雾里的,不过至少明白它是一个专门管理状态的,根据数据状态的改变可以驱动视图更新,既然是这样那至少登录注册是一种状态,就用登录来做测试,学习vuex,不过话说回来,既然专门管理状态,那我至少要仔细推敲一下这个learn的学习项目有那些状态逻辑。

详解Vuex管理登录状态

1、据说储存的vuex store里面的状态是临时的,右键刷新一下页面这些状态就销毁了(这是据说,请大神解惑我也没办法证实),如果是这样的话,我的用户状态user还是应该要写入sessionStorage,不然登录了的一刷新页面就变成没登录了,用户不就疯了啊。所以store里面的user状态应该要从sessionStorage里面去读。

2、在这个learn项目中现存的页面中,home,paroducts,FAQ,login,regin,应该是不需要登录就可以访问,而manger和manger以下的子页面是必须要登录才可以访问的。

3、比较特殊的是login和regin,如果用户已经登录了,再去访问这2个页面,原则上来说也是可以的,但如果已经登录了,再用其它账号来登录一次,那sessionStorage存在2个user数据,那就显然不合理了,所以应该规定,如果用户已经登录,又去访问login或者regin,那我们应先remove掉sessionStorage里面user数据

4、vuex规定所有状态的改变只能依靠mutation,而要驱动mutation去改变状态的只能是action。那在这个项目里登录状态变化只会有登录、注册和登出这三种情况,登录和注册成功的时候要去执行一个存在user的action,登出的时候去执行一个不存在user的action。

5、vuex官方还提了一个getter的玩意儿,我感觉应该是在我们需要取用store里面状态的时候,确切的说应该是取出这个状态之后,给这个状态做一些加工改变用的,而且应该只能getter一次吧,多了感觉要乱套啊(不知道这个想法对不对),但看见这样的写法this.$store.getters.doneTodosCount,感觉应该可以用不止一次把。估计我想得有点多了,目前看起来也用不上,也许要经历过需要的应用场景才能理解透彻把。

6、还有个module,这个就有点迷了,没太搞懂,先不管了

预想中store的登录状态还是要从sessionStorage来取的,所以我先把路由约束好,那些页面需要user,那些不需要,访问那些页面需要remove user

打开main.js

添加代码

// 这个官方名字叫导航守卫,挺形象的
router.beforeEach((to, from, next) => {
 // 如果是去登录或注册,那就先把user移除
 if (to.path === '/login' || to.path === '/regin') {
  sessionStorage.removeItem('user')
 }
 let user = JSON.parse(sessionStorage.getItem('user'))
 if (!user && (to.path === '/manger/my' || to.path === '/manger/send' || to.path === '/manger/history')) {
  next({ path: '/login' })
 } else {
  next()
 }
})

这样写感觉怪怪的,不知道有没有简单点的写法?

不过想要的效果是能达到的

然后尝试写store

先写个基本结构

详解Vuex管理登录状态

然后一步一步具体写

详解Vuex管理登录状态

是说这需要一个function?

唉哟,不对,我蠢了,这是赋值(不知道说赋值准不准确)嘛,又不是写一个obj对象,不需要逗号的哈

store.js

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)
// 创建基本状态
const state = {
 // 登录状态为没登录
 logined: false,
 // 用户信息数据,目前只需要avatar和name,还是把username也加上吧
 LoginedUser: {
  name: '',
  avatar: '',
  username: ''
 }
}
// 创建改变状态的方法
const mutations = {
 // 改变状态的方法也需要2个,一个是登录或注册了,一个是登出了
 // 这里不能写箭头函数???
 // 登录
 LOGIN (state) {
  // 先让登录状态变为登录了
  state.logined = true
  // 然后去sessionStorage取用户数据
  let user = JSON.parse(sessionStorage.getItem('user'))
  // 再把用户数据发下去
  state.LoginedUser.name = user.name
  state.LoginedUser.avatar = user.avatar
  state.LoginedUser.username = user.username
 },
 // 登出
 LOGOUT (state) {
  // 这个同理
  state.logined = false
  state.LoginedUser.name = ''
  state.LoginedUser.avatar = ''
  state.LoginedUser.username = ''
 }
}
// 创建驱动actions可以使得mutations得以启动
const actions = {
 // 这里先来一个驱动LOGIN的东西就叫login吧
 // 这个context是官方写的,应该叫什么无所谓
 login (context) {
  context.commit('LOGIN')
 },
 // 同样来个logout
 logout (context) {
  context.commit('LOGOUT')
 }
}

export default new Vuex.Store({
 state,
 mutations,
 actions
})

我感觉应该就这样就可以了吧,还是要测试一下

不对还应该要把action挂到该挂的地方,然后该引用store状态的地方引用store的数据

先去登录页面挂action

详解Vuex管理登录状态

应该是这样的,注册也是一样

详解Vuex管理登录状态

然后是登出的页面

header.vue

详解Vuex管理登录状态

同时我们就不在创建页面的时候从sessionStorage取数据了

还有一个main.js

详解Vuex管理登录状态

要是不能在main.js里面生效还真是麻烦啊,试想一下,已登录用户直接去了/login页面,seeionStorage里面用户数据清除了,但store里面的数据又没更新,那在头部不是还挂一个头像啊???

还有一步获取store里面的数据

header.vue

详解Vuex管理登录状态

还是赶紧测试一下吧

哭了.....直接四个错误

详解Vuex管理登录状态

这我都是照着官方说的写的啊

 详解Vuex管理登录状态

把header.vue的数据注释掉,还有一个错误

详解Vuex管理登录状态

但这个dispatch 是undefined 是啥意思啊,我是照着写的啊,大佬帮我解惑一下啊

详解Vuex管理登录状态

把dispatch 改成context 也不行

改成commit 试一下

详解Vuex管理登录状态

还是一样没脾气了,我再去看看资料吧

研究了好久解决了一部分问题

首先我把store.js,里面的action写成了这样

详解Vuex管理登录状态

但我觉得原来的写法也没有错

然后在main.js里面注释掉了这句

详解Vuex管理登录状态

然后就正常了,dispatch是正确的,所以我所担心的事果然发生了

先去登录

详解Vuex管理登录状态

详解Vuex管理登录状态

可以看见header右上方的确立刻变成了用户信息,达到了要求,然而我要是自己去地址栏输入/login

详解Vuex管理登录状态

详解Vuex管理登录状态

跳到了登录页面,但头像真的还挂在右上角........,说明store里面真的还是登录的数据,虽然仔细想想其实这并没有什么影响,他要是再一次登录成功,数据自然也就变了,而且一般没人会这么去访问登录页面,但心里觉得这样不对啊。

而且我觉得这个action的分发应该有办法写在main.js里面的,不知道有没有大神指点一二!

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

Javascript 相关文章推荐
js查找某元素中的所有图片地址的方法
Jan 16 Javascript
JavaScript生成随机字符串的方法
Mar 19 Javascript
javascript实现树形菜单的方法
Jul 17 Javascript
跟我学习javascript的prototype,getPrototypeOf和__proto__
Nov 17 Javascript
基于javascript实现最简单的选项卡切换效果
May 16 Javascript
JavaScript基础教程——入门必看篇
May 20 Javascript
AngularJS 应用身份认证的技巧总结
Nov 07 Javascript
js/jquery控制页面动态加载数据 滑动滚动条自动加载事件的方法
Feb 08 Javascript
vue 使用vue-i18n做全局中英文切换的方法
Oct 29 Javascript
小程序怎样让wx.navigateBack更好用的方法实现
Nov 01 Javascript
js实现简单扫雷
Nov 27 Javascript
vue3.0 上手体验
Sep 21 Javascript
Vue2 配置 Axios api 接口调用文件的方法
Nov 13 #Javascript
React通过父组件传递类名给子组件的实现方法
Nov 13 #Javascript
js设置随机切换背景图片的简单实例
Nov 12 #Javascript
AngularJS 表单验证手机号的实例(非必填)
Nov 12 #Javascript
基于js中style.width与offsetWidth的区别(详解)
Nov 12 #Javascript
浅谈webpack下的AOP式无侵入注入
Nov 12 #Javascript
JQ图片文件上传之前预览功能的简单实例(分享)
Nov 12 #Javascript
You might like
星际玩家的三大定律
2020/03/04 星际争霸
php切割页面div内容的实现代码分享
2012/07/31 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(九)
2014/06/24 PHP
php实现的双向队列类实例
2014/09/24 PHP
Yii2 中实现单点登录的方法
2018/03/09 PHP
php获取微信openid方法总结
2019/10/10 PHP
php实现的证件照换底色功能示例【人像抠图/换背景图】
2020/05/29 PHP
浅析jsopn跨域请求原理及cors(跨域资源共享)的完美解决方法
2017/02/06 Javascript
详解Node中导入模块require和import的区别
2017/08/11 Javascript
Angular搜索 过滤 批量删除 添加 表单验证功能集锦(实例代码)
2017/10/25 Javascript
vue集成百度UEditor富文本编辑器使用教程
2018/09/21 Javascript
微信小程序网络层封装的实现(promise, 登录锁)
2019/05/08 Javascript
JavaScript Math对象和调试程序的方法分析
2019/05/13 Javascript
vue中get请求如何传递数组参数的方法示例
2019/11/08 Javascript
vue-cli点击实现全屏功能
2020/03/07 Javascript
Python中多线程thread与threading的实现方法
2014/08/18 Python
Python中Iterator迭代器的使用杂谈
2016/06/20 Python
python3实现点餐系统
2019/01/24 Python
Tensorflow训练模型越来越慢的2种解决方案
2020/02/07 Python
python模拟斗地主发牌
2020/04/22 Python
Python爬虫headers处理及网络超时问题解决方案
2020/06/19 Python
Python内置函数及功能简介汇总
2020/10/13 Python
python利用 keyboard 库记录键盘事件
2020/10/16 Python
python爬取2021猫眼票房字体加密实例
2021/02/19 Python
CSS3实现鼠标悬停显示扩展内容
2016/08/24 HTML / CSS
美国大型的健身社区和补充商店:Bodybuilding.com
2016/09/06 全球购物
《蓝色的树叶》教学反思
2014/02/24 职场文书
体育课课后反思
2014/04/24 职场文书
公司感谢信范文
2015/01/22 职场文书
工会文体活动总结
2015/05/07 职场文书
换届选举主持词
2015/07/03 职场文书
入党宣誓大会后的感想
2015/08/10 职场文书
python的变量和简单数字类型详解
2021/09/15 Python
MySQL 表锁定 LOCK和UNLOCK TABLES的 SQL语法
2022/04/18 MySQL
win10怎么设置右下角图标不折叠?Win10设置右下角图标不折叠的方法
2022/07/15 数码科技
macos系统如何实现微信双开? mac登录两个微信以上微信的技巧
2022/07/23 数码科技