vue3实现简单登录页面

使用 Vue3 + ts + scss + element-plus 实现简单的用户登录界面,登录方式包括:手机验证码登录、手机账号密码登录、扫码登录,效果如下图所示:效果示意图
详细代码:
模版部分

<template>
  <div class="login">
    <div class="container">
      <div class="content">
        <h4>{{ title }}登录</h4>
        <div class="qr-code-area" v-if="loginType === 'qrcode'">
          <img src="@/assets/myblog.png" alt="myblog-qrcode" />
        </div>
        <div v-else class="account-area">
          <el-form ref="formRef" :rules="loginRules" :model="loginForm" label-width="auto"
            :hide-required-asterisk="true">
            <el-form-item label="手机号" prop="account">
              <el-input v-model="loginForm.account" placeholder="请输入手机号码">
                <template #prepend>+86</template>
              </el-input>
            </el-form-item>
            <el-form-item v-if="loginType === 'password'" prop="password" label="密码">
              <el-input v-model="loginForm.password" placeholder="请输入密码"></el-input>
            </el-form-item>
            <el-form-item v-if="loginType === 'vetifycode'" prop="vetifycode" label="验证码">
              <el-input v-model="loginForm.verifyCode" placeholder="请输入六位验证码" maxlength="6">
                <template #append>
                  <el-button type="primary" @click="handleSendVerifyCode">获取验证码</el-button>
                </template>
              </el-input>
            </el-form-item>
          </el-form>
          <router-link class="forget-area" v-if="loginType === 'password'" to="">忘记密码</router-link>
          <div class="operation-area">
            <el-button class="submit-btn" type="primary" @click="handleLogin">登录</el-button>
          </div>
        </div>
        <div class="change-login-type">
          <div :class="['login-type', loginType === 'vetifycode' && 'active']" @click="loginType = 'vetifycode'">手机号
          </div>
          <div :class="['login-type', loginType === 'password' && 'active']" @click="loginType = 'password'">账号密码</div>
          <div :class="['login-type', loginType === 'qrcode' && 'active']" @click="loginType = 'qrcode'">二维码</div>
        </div>
      </div>
    </div>
  </div>
</template>

TS部分

<script lang="ts" setup>
import { ElMessage } from 'element-plus';
import { computed, reactive, ref, watch } from 'vue';

const loginRules = {
  account: [
    { required: true, message: '请输入手机号码', trigger: 'blur' },
    { pattern: /^1\d{10}$/, message: "请输入正确的手机号码", trigger: "blur" }
  ],
  password: [{ required: true, message: '请输入密码', trigger: 'blur' }],
}

const formRef = ref<HTMLFormElement>(null);
const loginForm = reactive({
  account: '',
  password: '',
  verifyCode: ''
});
const loginType = ref<'password' | 'vetifycode' | 'qrcode'>('vetifycode');

const title = computed(() => {
  switch (loginType.value) {
    case 'password':
      return '账号密码'
    case 'vetifycode':
      return '短信验证码'
    case 'qrcode':
      return '扫码'
    default:
      return ''
  }
})

watch(loginType, () => {
  formRef?.value?.resetFields();
})

const handleSendVerifyCode = () => {
  formRef.value.validateField('account', (valid: boolean) => {
    if (valid) {
      ElMessage.info('您的验证码为:005114')
    }
  })
}

const handleLogin = () => {
  formRef.value.validate((vaild: boolean) => {
    if (vaild) {
      console.log('表单验证通过,提交接口验证信息')
      if (loginType.value === 'vetifycode' && loginForm.verifyCode !== '005114') {
        return ElMessage.error('验证码错误')
      }
      let message = '登录成功'
      if (loginForm.account) {
        message += ',登录的账号为' + loginForm.account;
      }
      if (loginForm.password) {
        message += ',登录的密码为' + loginForm.password;
      }
      if (loginForm.verifyCode) {
        message += ',登录的验证码为' + loginForm.verifyCode;
      }
      ElMessage.success(message)
    } else {
      console.log('验证失败');
    }
  })
}

</script>

Scss部分

<style lang="scss" scoped>
%bg {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.login {
  min-height: 675px;
  height: 100vh;
  width: 100vw;
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url(@/assets/bg.jpg);
  @extend %bg;
}

.container {
  width: 350px;
}

.content {
  color: #fff;
  width: 300px;
  background-color: #fff;
  border: 1px solid #eee;
  padding: 20px;
  box-shadow: -15px 15px 15px rgba(6, 17, 47, 0.7);
  background: linear-gradient(230deg,
      rgba(53, 57, 74, 0) 0%,
      rgb(0, 0, 0) 100%);
}

.account-area {
  margin-top: 50px;
}

:deep(.el-form-item__label) {
  color: #fff;
}

.qr-code-area {
  width: 200px;
  height: 200px;
  margin: 40px auto 20px auto;

  img {
    width: 100%;
    height: 100%;
  }
}

.forget-area {
  float: right;
  font-size: 13px;
  line-height: 16px;
  color: #267EF0;
}

.submit-btn {
  margin: 50px 0 30px 0;
  width: 100%;
}

.change-login-type {
  display: flex;
  border-top: 1px solid #eee;
  justify-content: space-between;
  padding-top: 10px;

  .login-type {
    font-size: 12px;
    line-height: 16px;
    text-align: center;
    color: #fff;
    width: 25%;
    position: relative;

    &:hover {
      cursor: pointer;
      color: #267EF0;
    }
  }

  .active {
    color: #267EF0;
  }

}
</style>

同志们,完整的登陆页面文件地址为:完整代码

欢迎大家有问题随时咨询奥,一起学习!

  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以给你提供一些基本的代码示例,但需要注意的是,登录页面还需要与后端进行交互,这部分代码并不在本示例中。 首先,我们需要创建一个Vue组件来实现登录页面,可以命名为Login.vue,代码如下: ```html <template> <div> <h2>用户登录</h2> <form> <div> <label>用户名:</label> <input type="text" v-model="username"> </div> <div> <label>密码:</label> <input type="password" v-model="password"> </div> <button @click.prevent="handleSubmit">登录</button> </form> </div> </template> <script> export default { data() { return { username: '', password: '' } }, methods: { handleSubmit() { // TODO: 进行登录验证 } } } </script> ``` 在上面的代码中,我们使用了Vue的模板语法来实现了一个简单的登录表单,包括用户名和密码的输入框以及一个登录按钮。在按钮上添加了一个点击事件,当用户点击登录按钮时,会触发handleSubmit方法。 接下来,我们需要在Vue实例中引入Login组件,并将其渲染到页面中。可以在App.vue实现,代码如下: ```html <template> <div id="app"> <Login /> </div> </template> <script> import Login from './components/Login.vue' export default { name: 'App', components: { Login } } </script> ``` 最后,我们需要在main.js中创建Vue实例并将其挂载到页面上,代码如下: ```js import { createApp } from 'vue' import App from './App.vue' createApp(App).mount('#app') ``` 至此,我们就完成了一个简单的使用Vue3实现的用户登录页面。接下来,你需要在handleSubmit方法中添加登录验证的相关代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值