一看就会的vuex实现登录验证(附案例)


Posted in Javascript onJanuary 09, 2020

一、vuex是啥?

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

简单来说,Vuex 类似 Redux 的状态管理器,用来管理Vue的所有组件状态。

当你打算开发大型单页应用(SPA),会出现多个视图组件依赖同一个状态,来自不同视图的行为需要变更同一个状态。

遇到以上情况时候,你就应该考虑使用Vuex了,它能把组件的共享状态抽取出来,当做一个全局单例模式进行管理。这样不管你在何处改变状态,都会通知使用该状态的组件做出相应修改。

vuex大体分为如下几部分:

  • state 用来数据共享数据存储
  • mutation 用来注册改变数据状态
  • getters 用来对共享数据进行过滤操作
  • action 解决异步改变共享数据
  • modules:store的子模块,为了开发大型项目,方便状态管理而使用的

二、vuex使用

1.首先创建一个vue-cli项目,这里不详述。

vue init webpack mylogin

2.安装vuex:

npm install vuex --save

3.在src目录下新建文件夹store,用来存放vuex内容

目录结构如下:

一看就会的vuex实现登录验证(附案例)

4.在main.js中引入vuex

import Vuex from 'vuex'
import store from './store'
Vue.use(Vuex)

一看就会的vuex实现登录验证(附案例)

5.在store文件夹下新建state.js,vuex用来存储数据
内容如下:

const state={
 userInfo:''
}
export default state;

userInfo用来保存用户信息,根据是否有值来判断跳转页面。

6.在store文件夹下新建multation.js,用来修改vuex中存储的数据
内容如下:

const mutations={
 login(state,v){
  state.userInfo=v;
 }
}
export default mutations;

7.在store文件夹下新建index.js,用来初始化vuex
内容如下:

import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import mutations from './multation'

Vue.use(Vuex);
const store =new Vuex.Store({
 state,
 mutations
})
export default store;

此时在浏览器中就可以看到如下(浏览器需增加插件vue devTools):

一看就会的vuex实现登录验证(附案例)

8.本项目界面如下

主页面和登陆页面

一看就会的vuex实现登录验证(附案例)

9.login.vue提交方法如下:

submitBtn(){
 let me=this;
 if(!me.user.username||!me.user.pwd){
  alert("用户名或密码不能为空");
 }
 else {
  this.$store.commit('login',this.user);
  this.$router.push('./');
 }
}

通过commit实现执行multations里刚才定义的login方法。即当点击登陆时state中的userInfo已经被赋值。接下来通过判断此字段是否有值来进行页面跳转。

10.在main.js用router.beforeEach方法对vuex中的userInfo进行判断

router.beforeEach(function(to,from,next){
 if(store.state.userInfo||to.path==='/login'){
  next();
 }
 else {
  next({path:'/login'})
 }
})

效果图:

一看就会的vuex实现登录验证(附案例)

登陆后:

一看就会的vuex实现登录验证(附案例)

案例地址:https://github.com/myweiwei/vuex-login

将不断更新完善,期待您的批评指正!

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

Javascript 相关文章推荐
jquery无缝向上滚动实现代码
Mar 29 Javascript
jQuery+PHP实现动态数字展示特效
Mar 14 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
Jun 04 Javascript
javascript中一些util方法汇总
Jun 10 Javascript
基于Bootstrap的Metronic框架实现页面链接收藏夹功能
Aug 29 Javascript
node.js中express中间件body-parser的介绍与用法详解
May 23 Javascript
详解vue-resource promise兼容性问题
Jun 20 Javascript
关于JavaScript中forEach和each用法浅析
Jul 27 Javascript
Angular使用ControlValueAccessor创建自定义表单控件
Mar 08 Javascript
TensorFlow.js 微信小程序插件开始支持模型缓存的方法
Feb 21 Javascript
基于VUE实现判断设备是PC还是移动端
Jul 03 Javascript
vue 中this.$set 动态绑定数据的案例讲解
Jan 29 Vue.js
Websocket 向指定用户发消息的方法
Jan 09 #Javascript
Vue快速实现通用表单验证的示例代码
Jan 09 #Javascript
JS实现商品橱窗特效
Jan 09 #Javascript
微信小程序实现页面浮动导航
Jan 08 #Javascript
微信小程序基于movable-view实现滑动删除效果
Jan 08 #Javascript
小程序自定义模板实现吸顶功能
Jan 08 #Javascript
微信小程序静默登录的实现代码
Jan 08 #Javascript
You might like
PHP5 安装方法
2006/10/09 PHP
PHP新手上路(十三)
2006/10/09 PHP
php数据结构与算法(PHP描述) 查找与二分法查找
2012/06/21 PHP
深入浅出讲解:php的socket通信原理
2016/12/03 PHP
laravel在中间件内生成参数并且传递到控制器中的2种姿势
2019/10/15 PHP
jquery.simple.tree插件 更简单,兼容性更好的无限树插件
2010/09/03 Javascript
jquery中each方法示例和常用选择器
2014/07/08 Javascript
js实现类似于add(1)(2)(3)调用方式的方法
2015/03/04 Javascript
解决node.js安装包失败的几种方法
2016/09/02 Javascript
微信小程序 解决swiper不显示图片的方法
2017/01/04 Javascript
JS图片轮播与索引变色功能实例详解
2017/07/06 Javascript
Angular4绑定html内容出现警告的处理方法
2017/11/03 Javascript
jQuery实现弹窗下底部页面禁止滑动效果
2017/12/19 jQuery
javascript自定义日期比较函数用法示例
2019/07/22 Javascript
[02:28]DOTA2亚洲邀请赛 LGD战队巡礼
2015/02/03 DOTA
Python cx_freeze打包工具处理问题思路及解决办法
2016/02/13 Python
Python中不同进制的语法及转换方法分析
2016/07/27 Python
python中format()函数的简单使用教程
2018/03/14 Python
django静态文件加载的方法
2018/05/20 Python
python 解决selenium 中的 .clear()方法失效问题
2020/09/01 Python
浅析PyCharm 的初始设置(知道)
2020/10/12 Python
澳大利亚婴儿、幼儿和儿童在线设计师商店:Smooch Baby
2019/02/16 全球购物
可持续未来的时尚基础:Alternative Apparel
2019/05/06 全球购物
美国一家著名的手表在线折扣网站:Discount Watch Store
2020/02/24 全球购物
一套带网友答案的.NET笔试题
2016/12/06 面试题
2014年乡镇卫生院工作总结
2014/11/24 职场文书
如何书写读后感?(附范文)
2019/07/26 职场文书
大学校园餐饮创业计划书
2019/08/07 职场文书
springboot 启动如何排除某些bean的注入
2021/08/02 Java/Android
《艾尔登法环》1.03.3补丁上线 碎星伤害调整
2022/04/07 其他游戏
vue配置型表格基于el-table拓展之table-plus组件
2022/04/12 Vue.js
Python绘制散乱的点构成的图的方法
2022/04/21 Python
win10忘记pin密码登录不了怎么办?win10忘记pin密码登不进去的解决方法
2022/07/07 数码科技
使用 DataAnt 监控 Apache APISIX的原理解析
2022/07/07 Servers
css弧边选项卡的项目实践
2023/05/07 HTML / CSS
postgresql中如何执行sql文件
2023/05/08 PostgreSQL