Vue+localstrong登录注册,并保持登录状态
在router.js中添加meta区分
比如登录注册页面,不需要登录即可进入,那么我们把meta中的isLogin标志设置为false
{
//登录
path: '/login',
component: login,
meta: {
isLogin: false
}
},
{
//注册
path: '/register',
component: register,
meta: {
isLogin: false
}
},
而在首页我们需要登录才能进入,那么我们把meta中的isLogin标志设置为true
{
//首页
path: '/home',
component: home,
meta: {
isLogin: true
},
}
这样我们就为进入各个路由是否需要登录做了区分。
接下来我们在login.vue中修改登录后状态
我们使用axios向后台发起登录请求
this.$axios.post("/xxx/login", {user:name,password:pwd})
.then(data => {
//登录失败,先不讨论
if (data.data.status != 200) {
//iViewUi的友好提示
this.$Message.error(data.data.message);
//登录成功
} else {
//设置Vuex登录标志为true,默认userLogin为false
this.$store.dispatch("userLogin", true);
//Vuex在用户刷新的时候userLogin会回到默认值false,所以我们需要用到HTML5储存
//我们设置一个名为Flag,值为isLogin的字段,作用是如果Flag有值且为isLogin的时候,证明用户已经登录了。
localStorage.setItem("Flag", "isLogin");
//iViewUi的友好提示
this.$Message.success(data.data.message);
//登录成功后跳转到指定页面
this.$router.push("/home");
}
});
Vuex里面我是这样写的(如果项目不需要Vuex,那么直接使用HTML5储存就可以了):
export const store = new Vuex.Store({
// 设置属性
state: {
isLogin: false,
},
// 获取属性的状态
getters: {
//获取登录状态
isLogin: state => state.isLogin,
},
// 设置属性状态
mutations: {
//保存登录状态
userStatus(state, flag) {
state.isLogin = flag
},
},
// 应用mutations
actions: {
//获取登录状态
setUser({commit}, flag) {
commit("userStatus", flag)
},
}
})
在mian.js里
router.beforeEach((to, from, next) => {
//获取用户登录成功后储存的登录标志
let getFlag = localStorage.getItem("Flag");
//如果登录标志存在且为isLogin,即用户已登录
if(getFlag === "isLogin"){
//设置vuex登录状态为已登录
store.state.isLogin = true
next()
//如果已登录,还想想进入登录注册界面,则定向回首页
if (!to.meta.isLogin) {
//iViewUi友好提示
iView.Message.error('请先退出登录')
next({
path: '/home'
})
}
//如果登录标志不存在,即未登录
}else{
//用户想进入需要登录的页面,则定向回登录界面
if(to.meta.isLogin){
next({
path: '/login',
})
//iViewUi友好提示
iView.Message.info('请先登录')
//用户进入无需登录的界面,则跳转继续
}else{
next()
}
}
});
router.afterEach(route => {
window.scroll(0, 0);
});
Vue+localstrong登录注册,并保持登录状态的更多相关文章
- 结合数据库登录注册模块,登录成功之后跳到WebView
最近刚刚做了一个模块,在本地建立一个数据库,存储注册的账号,登录的时候取出,正确则登录,登录之后跳到一个webView网页. 直接上代码吧. LoginActivity.java package co ...
- nodejs+express+mongodb实现登录注册
nodejs+express+mongodb实现登录注册 1 简介 登录注册功能使用nodejs+express+mongodb完成,其中对mongodb的操作使用mongoose完成,对mongod ...
- Vue登录注册,并保持登录状态
关于vue登录注册,并保持登录状态,是vue玩家必经之路,网上也有很多的解决方法,但是有一些太过于复杂,新手可能会看的一脸懵逼,现在给大家介绍一种我自己写项目在用而且并不难理解的一种方法. 项目中有一 ...
- 基于 Vue + Koa2 + MongoDB + Redis 实现一个完整的登录注册
项目地址:https://github.com/caochangkui/vue-element-responsive-demo/tree/login-register 通过 vue-cli3.0 + ...
- vue+Mint-ui实现登录注册
创建一个组件:注册组件 (register/index.vue.script.js.style.scss,register/header) 注册路由 router/index.js { path: ' ...
- 用vue开发一个app(4,一个久等了的文章)H5直播平台登录注册(1)
我上一篇关于vue的文章和这一篇时间隔了有点久了.最近终于写完了. 因为我一直想写个有点实绩的东西,而不是随便写一个教程一样东西.结合最近在项目中学到的经验和我的一点创意. 首先介绍下这是个什么! H ...
- vue.js+koa2项目实战(三)登录注册模态框
登录注册模态框 注: [Vue warn]: Do not use built-in or reserved HTML elements as component id: diaLog 原因:diaL ...
- vue.js实现用户评论、登录、注册、及修改信息功能
vue.js实现用户评论.登录.注册.及修改信息功能:https://www.jb51.net/article/113799.htm
- Vue学习之路之登录注册实例代码
Vue学习之路之登录注册实例代码:https://www.jb51.net/article/118003.htm vue项目中路由验证和相应拦截的使用:https://blog.csdn.net/wa ...
随机推荐
- JavaEEspring整理
Spring框架—控制反转(IOC) 1 Spring框架概述 1.1 什么是Spring 1.2 S ...
- 使用Redis实现实时排行榜
游戏中存在各种各样的排行榜,比如玩家的等级排名.分数排名等.玩家在排行榜中的名次是其实力的象征,位于榜单前列的玩家在虚拟世界中拥有无尚荣耀,所以名次也就成了核心玩家的追求目标. 一个典型的游戏排行榜包 ...
- 野路子码农系列(2)Python中的类,可能是最通俗的解说
啥叫佩奇?啥叫类?啥叫面向对象?后面两个问题以前在大学里“祖传谭浩强”的时候我经常会有所疑问.老师说着一堆什么public, private,我都是一脸懵逼,啥叫私有?为啥要私有?然后就神游天外了…… ...
- 【转载】C++ STL快速入门
https://www.cnblogs.com/skyfsm/p/6934246.html
- VS Less Compiler插件使用
1.打开扩展管理器,下载安装 2.新建一个test.less文件 3.敲入代码 @grayback: #808080; body { background:@grayback; } 4.保存即可自动生 ...
- mysql 一张表的数据插入另一张表的sql语句
1. 表结构完全一样 insert into 表1 select * from 表2 2. 表结构不一样(这种情况下得指定列名) insert into 表(列名1,列名2,列名3) select 列 ...
- 利用crontab定时提交svn遇到的几个问题
交待下背景...公司开发组只有技术经理有服务器和数据库权限,还只是开发环境的..因为工作安排和权限限制,测试同学上线的时候,需要本人帮开发组的部分同事review代码并把代码提交到trunk.一开始手 ...
- html的分类与特点
##块级元素##|元素|描述||--|--||h1-h6|标题||div|区分大模块||p|段落||ul>li|无序列表||ol>li|有序列表||dl>dt dd|自定义列表||t ...
- Git分支实战入门详细图解
现在我们模拟一个简单的分支和合并案例,其中工作流可供真实项目借鉴. (1)在master开展工作 (2)为新的需求创建分支 (3)在新的分支上展开工作 这时,你接到一个电话,说项目有一个严重的问题需要 ...
- python捕获异常及方法总结
调试Python程序时,经常会报出一些异常,异常的原因一方面可能是写程序时由于疏忽或者考虑不全造成了错误,这时就需要根据异常Traceback到出错点,进行分析改正:另一方面,有些异常是不可避免的,但 ...