vue+element-ui +axios+less+webpack 实现登录退出功能

先来看效果
vue+element-ui +axios+less+webpack 实现登录退出功能_第1张图片
登录退出功能依赖数据库后台的一些配置,这里只是使用vue来实现这个功能

1:首先使用 vue脚手架可视化图形界面,搭建vue项目
vue+element-ui +axios+less+webpack 实现登录退出功能_第2张图片
项目搭建完毕
2:开启数据库,并且将数据导入数据库
vue+element-ui +axios+less+webpack 实现登录退出功能_第3张图片
3:开启服务器,这里是node写的服务器
vue+element-ui +axios+less+webpack 实现登录退出功能_第4张图片

下面开始写登录退出功能

  1. 界面的绘制
 <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,利用编程式导航,跳转到登录页

详细代码在码云

需要素材或者程序出错,欢迎交流

完整代码

你可能感兴趣的:(vue,vue.js)