先来看效果
登录退出功能依赖数据库后台的一些配置,这里只是使用vue来实现这个功能
1:首先使用 vue脚手架可视化图形界面,搭建vue项目
项目搭建完毕
2:开启数据库,并且将数据导入数据库
3:开启服务器,这里是node写的服务器
下面开始写登录退出功能
- 界面的绘制
<div class="login_container">
<div class="login_box">
<div class="avatar_box">
<img src="../assets/logo.png" alt />
</div>
<!-- 表单区域 -->
<el-form class="login_form" :model="loginForm" :rules="loginFormRules" ref="loginFormRefs">
<!-- 用户名 -->
<el-form-item prop="username">
<el-input prefix-icon="iconfont icon-user" v-model="loginForm.username"></el-input>
</el-form-item>
<!-- 密码 -->
<el-form-item prop="password">
<el-input
prefix-icon="iconfont icon-3702mima"
v-model="loginForm.password"
type="password"
></el-input>
</el-form-item>
<!-- 登录 -->
<el-form-item class="login_btn">
<el-button type="primary" @click="login">登录</el-button>
<!-- 注册 -->
<el-button type="info" @click="resetForm">重置</el-button>
</el-form-item>
</el-form>
</div>
</div>
界面的绘制主要使用element ui来绘制,这里用到了表单组件,所以在element.js里面需要导入组件
import { Form } form 'element-ui'
import { FormItem } form 'element-ui'
import { Button } form 'element-ui'
全局注册到vue实例上面
Vue.use(Form)
Vue.use(FormItem)
Vue.use(Button)
表单的属性
:model:绑定值
:rules:表单校验规则
ref='' 表单的引用,通过this.$refs.引用名来获取表单引用对象(实例对象)
重置表单
1:获取到表单对象
2:调用重置表单的resetFields方法
登录
1:在登录的时候,先进行表单的预校验
+. validate是对整个表单进行校验的方法,参数为一个回调函数,回调函数的第一个形参是一个布尔值,通过true
+. 校验规则rules是对填写的数据是否合法进行校验,validatte是对表单是否完成填写
2: 校验通过,调用接口,请求数据
3: 使用async await 来接收post请求后台接口返回的数据。并且判断其状态是否是接口提供的正确状态。如果是,将数据存储变量中。不是弹框提示用户,登录失败
4:将登录之后token存储在token,保存到客户端的sessionStroge
+. token只有在当前打开的项目才有效,所以选择了sessionStroge中
5: 登录成功,通过编程式导航,跳转到home页
出现一个问题:如果别人不在我这个网页登录,在地址栏随便输入一个字段和我接口字段相同,就可以随意登录了。 用到了vue中的路由守卫
router.beforeEach((to, from, next) => {
if (to.path === '/login') next();
// 从sessionStroge中获取token值
const tokenStr = window.sessionStorage.getItem("token");
if (!tokenStr) return next('/login');
next();
})
1:先调用路由钩子函数,在里面传入一个参数,是一个function,function里面传入三个参数
(和promise有点相似)
2. 如果去的路径是登录页面,放行
3. 如果不是登录页面跳转到登录页面
退出
清除token,利用编程式导航,跳转到登录页
详细代码在码云
需要素材或者程序出错,欢迎交流