一看就会的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 相关文章推荐
在html页面上拖放移动标签
Jan 08 Javascript
vs2003 js文件编码问题的解决方法
Mar 20 Javascript
来自国外的30个基于jquery的Web下拉菜单
Jun 22 Javascript
javascript中兼容主流浏览器的动态生成iframe方法
May 05 Javascript
jQuery实现Div拖动+键盘控制综合效果的方法
Mar 10 Javascript
Bootstrap的popover(弹出框)2秒后定时消失的实现代码
Feb 27 Javascript
详解vue2.0 transition 多个元素嵌套使用过渡
Jun 19 Javascript
Vue 中使用 CSS Modules优雅方法
Apr 09 Javascript
Vue插值、表达式、分隔符、指令知识小结
Oct 12 Javascript
用npm-run实现自动化任务的方法示例
Jan 14 Javascript
Vue 事件处理操作实例详解
Mar 05 Javascript
详解Vue源码学习之双向绑定
Apr 10 Javascript
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
PHP写MySQL数据 实现代码
2009/06/15 PHP
php 获取当前访问的url文件名的方法小结
2010/02/08 PHP
PHP中break及continue两个流程控制指令区别分析
2011/04/18 PHP
destoon常用的安全设置概述
2014/06/21 PHP
定义select的边框颜色
2008/04/28 Javascript
JavaScript 学习笔记(五)
2009/12/31 Javascript
读jQuery之七 判断点击了鼠标哪个键的代码
2011/06/21 Javascript
js实现拖拽 闭包函数详细介绍
2012/11/25 Javascript
编写高性能Javascript代码的N条建议
2015/10/12 Javascript
基于JavaScript实现高德地图和百度地图提取行政区边界经纬度坐标
2016/01/22 Javascript
AngualrJS中每次$http请求时的一个遮罩层Directive
2016/01/26 Javascript
Java框架SSH结合Easyui控件实现省市县三级联动示例解析
2016/06/12 Javascript
简单实现jQuery级联菜单
2017/01/09 Javascript
浅谈在vue项目中如何定义全局变量和全局函数
2017/10/24 Javascript
详解微信小程序实现WebSocket心跳重连
2018/07/31 Javascript
Javascript删除数组里的某个元素
2019/02/28 Javascript
微信小程序时间戳转日期的详解
2019/04/30 Javascript
通过实例了解Javascript柯里化流程
2020/03/03 Javascript
[58:37]Serenity vs Fnatic 2018国际邀请赛淘汰赛BO1 8.21
2018/08/22 DOTA
Python对文件操作知识汇总
2016/05/15 Python
Python计算斗牛游戏概率算法实例分析
2017/09/26 Python
python 编码规范整理
2018/05/05 Python
Python实现登陆文件验证方法
2018/10/06 Python
把pandas转换int型为str型的方法
2019/01/29 Python
Python常用特殊方法实例总结
2019/03/22 Python
python时间序列按频率生成日期的方法
2019/05/14 Python
Python Pandas 箱线图的实现
2019/07/23 Python
python elasticsearch从创建索引到写入数据的全过程
2019/08/04 Python
Python matplotlib画曲线例题解析
2020/02/07 Python
如何使用python写截屏小工具
2020/09/29 Python
HTML5使用drawImage()方法绘制图像
2014/06/23 HTML / CSS
好药师网上药店:安全合法的网上药品零售药房
2017/02/15 全球购物
开放系统互连参考模型
2016/06/29 面试题
2014年底个人工作总结
2015/03/10 职场文书
2015年老干部工作总结
2015/04/23 职场文书
技能培训通讯稿
2015/07/18 职场文书