vue实现登录界面

 更新时间:2022年06月16日 16:12:42   作者:Hi-Sun  
这篇文章主要为大家详细介绍了vue实现登录界面,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

使用Vue实现简单的用户登录界面,登录成功以后查询账号用户类型进行相应的页面路由跳转,效果如下图所示:

HTML部分:

<div class="loginbody">
    <div class="login">
      <div class="mylogin" align="center">
        <h4>登录</h4>
        <el-form
          :model="loginForm"
          :rules="loginRules"
          ref="loginForm"
          label-width="0px"
        >
          <el-form-item
            label=""
            prop="account"
            style="margin-top:10px;"
          >
            <el-row>
              <el-col :span='2'>
                <span class="el-icon-s-custom"></span>
              </el-col>
              <el-col :span='22'>
                <el-input
                  class="inps"
                  placeholder='账号'
                  v-model="loginForm.account">
                </el-input>
              </el-col>
            </el-row>
          </el-form-item>
          <el-form-item
            label=""
            prop="passWord"
          >
            <el-row>
              <el-col :span='2'>
                <span class="el-icon-lock"></span>
              </el-col>
              <el-col :span='22'>
                <el-input
                  class="inps"
                  type="password"
                  placeholder='密码'
                  v-model="loginForm.passWord"
                ></el-input>
              </el-col>
            </el-row>
          </el-form-item>
          <el-form-item style="margin-top:55px;">
            <el-button
              type="primary"
              round
              class="submitBtn"
              @click="submitForm"
            >登录
            </el-button>
          </el-form-item>
          <div class="unlogin">
            <router-link :to="{ path: '/forgetpwd'}">
              忘记密码?
            </router-link>
            |
            <router-link :to="{path: '/register'}">
              <a href="register.vue" target="_blank" align="right">注册新账号</a>
            </router-link>
          </div>
        </el-form>
      </div>
    </div>
  </div>

JS部分

 import {mapMutations} from "vuex";
 
  export default {
    name: "Login",
    data: function () {
      return {
        loginForm: {
          account: '',
          passWord: ''
        },
        loginRules: {
          account: [
            {required: true, message: "请输入账号", trigger: "blur"}
          ],
          passWord: [{required: true, message: "请输入密码", trigger: "blur"}]
        }
      }
    },
   
    methods: {
      ...mapMutations(['changeLogin']),
      submitForm() {
        let self = this;
        const userAccount = this.loginForm.account;
        const userPassword = this.loginForm.passWord;
        const userForm = new FormData();
        userForm.append('userAccount', userAccount);
        userForm.append('userPassword', userPassword);
        this.axios.post('URL1', userForm
        ).then((res) => {
          if (res.data == 0) {
            self.$message({
              type: 'error',
              message: '密码错误,登陆失败!'
            })
          }
          //token
          self.sessiontoken = res.headers['sessiontoken'];
          self.PageToken = Math.random().toString(36).substr(2);
          sessionStorage.setItem('PageToken', self.PageToken);
          self.changeLogin({sessiontoken: self.sessiontoken});
          //登录成功
          if (res.data == 1) {
            self.axios.get("URL2"
            ).then((res) => {
              if (res.data == null) {
                self.$message({
                  type: 'error',
                  message: '查询失败!'
                })
              } else {
                if (res.data.userType == 0) {
                  self.$router.push({path: '/supermana', replace: true})
                } else if (res.data.userType == 1) {
                  self.$router.push({path: '/manauser', replace: true})
                } else if (res.data.userType == 2) {
                  self.$router.push({path: '/ordinauser', replace: true})
                }
              }
            }).catch((error) => {
              console.log(error)
            })
          }
        })
      },
    }
  }

CSS部分

 .loginbody {
    overflow: scroll;
    overflow-y: hidden;
    overflow-x: hidden;
  }
 
  .login {
    width: 100vw;
    padding: 0;
    margin: 0;
    height: 100vh;
    font-size: 16px;
    background-position: left top;
    background-color: #242645;
    color: #fff;
    font-family: "Source Sans Pro";
    position: relative;
    background-image: url('/static/images/background.jpg');
    background-repeat: no-repeat;
    background-size: 100% 100%;
  }
 
  .mylogin {
    width: 240px;
    height: 280px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    padding: 50px 40px 40px 40px;
    box-shadow: -15px 15px 15px rgba(6, 17, 47, 0.7);
    opacity: 1;
    background: linear-gradient(
      230deg,
      rgba(53, 57, 74, 0) 0%,
      rgb(0, 0, 0) 100%
    );
  }
 
  .inps input {
    border: none;
    color: #fff;
    background-color: transparent;
    font-size: 12px;
  }
 
  .submitBtn {
    background-color: transparent;
    color: #39f;
    width: 200px;
  }

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

相关文章

  • vue基于session和github-oauth2实现登录注册验证思路详解

    vue基于session和github-oauth2实现登录注册验证思路详解

    通过 sessionId 可以在 session 表中获取用户的信息,此外,还利用 session 表实现了GitHub 的 OAuth2 第三方登录,本文讲解前端通过简单的方式实现一个基本的登录注册验证功能,感兴趣的朋友跟随小编一起看看吧
    2024-08-08
  • uniapp实现省市区三级级联选择功能(含地区json文件)

    uniapp实现省市区三级级联选择功能(含地区json文件)

    这篇文章主要给大家介绍了关于uniapp实现省市区三级级联选择功能(含地区json文件)的相关资料,级级联是一种常见的网页交互设计,用于省市区选择,它的目的是方便用户在一系列选项中进行选择,并且确保所选选项的正确性和完整性,需要的朋友可以参考下
    2024-06-06
  • 解决vue watch数据的方法被调用了两次的问题

    解决vue watch数据的方法被调用了两次的问题

    这篇文章主要介绍了解决vue watch数据的方法被调用了两次的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue绑定class与行间样式style详解

    vue绑定class与行间样式style详解

    这篇文章主要介绍了vue绑定class与行间样式style的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • Vue可左右滑动按钮组组件使用详解

    Vue可左右滑动按钮组组件使用详解

    这篇文章主要为大家详细介绍了基于Vue可左右滑动按钮组组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Vue 中文本内容超出规定行数后展开收起的处理的实现方法

    Vue 中文本内容超出规定行数后展开收起的处理的实现方法

    这篇文章主要介绍了Vue 中文本内容超出规定行数后展开收起的处理的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • VUE3+Element-plus中el-form的使用示例代码

    VUE3+Element-plus中el-form的使用示例代码

    这篇文章主要介绍了VUE3+Element-plus中el-form的使用示例代码,本文通过图文示例代码相结合给大家介绍的非常详细,需要的朋友可以参考下
    2024-07-07
  • vue-cli解决IE浏览器sockjs-client错误方法

    vue-cli解决IE浏览器sockjs-client错误方法

    这篇文章主要为大家介绍了vue-cli解决IE浏览器sockjs-client错误方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • Vue+Three加载glb文件报错问题及解决

    Vue+Three加载glb文件报错问题及解决

    当使用Three.js加载GLB模型时,遇到加载错误常常是路径问题,解决方案:1. 将GLB模型文件置于public目录,避免打包时路径编码变化;2. 从node_modules的three库中复制draco解码器至public目录;3. 确认场景、摄像机和光源设置正确
    2024-10-10
  • Vue引入使用localforage改进本地离线存储方式(突破5M限制)

    Vue引入使用localforage改进本地离线存储方式(突破5M限制)

    这篇文章主要介绍了Vue引入使用localforage改进本地离线存储方式(突破5M限制),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论