vue3+ts+elementplus写一个登录页面教程

简介: 【6月更文挑战第3天】本文介绍了如何使用 Vue 3 和 TypeScript 创建一个登录页面。首先,需安装 Vue CLI,然后创建新项目并启用 TypeScript 支持。接着,创建 `Login.vue` 组件,设计登录表单,包括用户账号、密码和验证码字段,并实现相关验证规则。页面样式包括背景、登录框和按钮等元素的布局与样式。最后,展示了`<script>`部分的代码,包括表单验证逻辑、生成验证码的函数以及登录提交处理。文章还提供了一个登录页面的截图和完整代码示例。

前言

前期准备步骤:

创建一个使用 Vue 3 和 TypeScript 的登录页面涉及到多个步骤。以下是一个基本的教程,帮助你从头开始构建这样一个页面:

1. 安装 Vue CLI 和 TypeScript 支持

首先,你需要安装 Vue CLI 并配置它以支持 TypeScript。如果你还没有安装 Vue CLI,可以通过以下命令进行安装:

npm install -g @vue/cli  
# OR  
yarn global add @vue/cli

然后,你可以创建一个新的 Vue 3 项目并启用 TypeScript 支持:

vue create my-login-app

在创建过程中,选择 “Manually select features”,然后勾选 “TypeScript” 和其他你需要的特性(比如 Router、Linter/Formatter 等)。

2. 创建登录组件

在 src/views目录下创建一个新的 TypeScript 文件,比如 Login.vue。这个文件将包含你的登录表单和逻辑。

文章重点内容

页面样式:

页面代码:

<div class="login-right-warp">
        <div class="login-right-warp-title">login</div>
        <div class="login-right-warp-form">
          <div class="login-right-warp-form_title">用户名登录</div>
          <el-form ref="ruleFormRef" style="max-width: 600px" :model="ruleForm" status-icon :rules="rules"
            label-width="auto" class="demo-ruleForm">
            <el-form-item prop="AccountNo">
              <el-input v-model="ruleForm.AccountNo" autocomplete="off" :prefix-icon="User"
                placeholder="请输入账号" />
            </el-form-item>
            <el-form-item prop="AccountPwd">
              <el-input v-model="ruleForm.AccountPwd" type="password" autocomplete="off" :prefix-icon="Lock"
                placeholder="请输入密码" />
            </el-form-item>
            <el-form-item prop="Code">
              <el-input v-model.number="ruleForm.Code" :prefix-icon="Promotion" class="login-content-code"
                placeholder="请输入验证码" />
              <span class="login-content-code-img" @click="generateCodeAsync()">{{ verificationCode.Code
              }}</span>
            </el-form-item>
            <el-form-item>
              <el-button type="primary" @click="submitForm(ruleFormRef)">登录</el-button>
            </el-form-item>
          </el-form>
          <div class="login-msg">* 温馨提示:建议使用谷歌、Microsoft Edge,版本 79.0.1072.62 及以上浏览器,360浏览器请使用极速模式</div>
        </div>
      </div>

script代码:

import { reactive, onMounted, ref } from 'vue';
import type { FormInstance, FormRules } from 'element-plus';
import { User, Lock, Promotion } from '@element-plus/icons-vue';
import { postLoginAsync, postGenerateCodeAsync } from '@/api/login';
import { useRouter } from 'vue-router';
// 使用 Vue Router 的 useRouter 函数来获取 router 实例
const router = useRouter();
const ruleFormRef = ref<FormInstance>();
// 页面加载时
onMounted(() => {
  generateCodeAsync();
});
const validateCodeKey = (rule: any, value: any, callback: any) => {
  if (value === '') {
    callback(new Error('请输入验证码'));
  } else {
    callback();
  }
};
const validateAccountNo = (rule: any, value: any, callback: any) => {
  if (value === '') {
    callback(new Error('请输入账号'));
  } else {
    callback();
  }
};
const validateAccountPwd = (rule: any, value: any, callback: any) => {
  if (value === '') {
    callback(new Error('请输入密码'));
  } else {
    callback();
  }
};
const ruleForm = reactive({
  AccountNo: '123',
  AccountPwd: '',
  CodeKey: '',
  Code: '',
});
const verificationCode = reactive({
  CodeKey: '',
  Code: '',
});
const rules = reactive<FormRules<typeof ruleForm>>({
  AccountNo: [{ validator: validateAccountNo, trigger: 'blur' }],
  AccountPwd: [{ validator: validateAccountPwd, trigger: 'blur' }],
  Code: [{ validator: validateCodeKey, trigger: 'blur' }],
});
const generateCodeAsync = () => {
  postGenerateCodeAsync().then((res: any) => {
    verificationCode.Code = res.Data.Code;
    verificationCode.CodeKey = res.Data.Key;
    ruleForm.CodeKey = res.Data.Key;
  });
};
const submitForm = (formEl: FormInstance | undefined) => {
  if (!formEl) return;
  formEl.validate((valid) => {
    if (valid) {
      console.log('submit!');
      router.push('/home');
    } else {
      console.log('error submit!');
      return false;
    }
  });
};
</script>

样式代码:

.login {
  width: 100vw;
  height: 100vh;
  background: #fff;
  .login-left {
    .login-left-logo {
      display: flex;
      align-items: center;
      position: absolute;
      top: 50px;
      left: 80px;
      z-index: 1;
      animation: logoAnimation 0.3s ease;
      img {
        width: 100px;
        height: 64px;
      }
      .login-left-logo-text {
        display: flex;
        flex-direction: column;
      }
      .login-left-logo-text span {
        margin-left: 10px;
        font-size: 30px;
        font-weight: 700;
        color: #de2910;
      }
      .login-left-logo-text .login-left-logo-text-msg {
        font-size: 12px;
        color: #de2910;
      }
    }
    .login-left-img {
      width: 90%;
      margin: 70px 0 0px 10%;
      height: 90%;
      min-height: 500px;
      min-width: 500px;
      display: flex;
      justify-content: center;
      align-items: center;
      img {
        height: 500px;
        min-width: 500px;
      }
    }
  }
  .login-right {
    width: 650px;
    .login-right-warp {
      border: 1px solid #e76959;
      border-radius: 3px;
      width: 500px;
      height: 550px;
      position: relative;
      overflow: hidden;
      background-color: #fff;
      margin: auto;
      .login-right-warp-title {
        height: 130px;
        line-height: 130px;
        font-size: 32px;
        font-weight: 800;
        text-align: center;
        animation: logoAnimation 0.3s ease;
        animation-delay: 0.3s;
        color: #f00;
      }
      .login-right-warp-form {
        padding: 0 50px 50px;
      }
      .login-right-warp-form_title {
        color: #de2910;
        width: 100%;
        padding: 10px 0px;
        border-bottom: 1px solid #e4e7ed;
        position: relative;
      }
      .login-right-warp-form_title::after {
        content: '';
        position: absolute;
        width: 90px;
        height: 2px;
        background: #de2910;
        bottom: 0;
        left: 0px;
      }
    }
    .el-form {
      margin-top: 30px;
    }
    .el-input {
      width: 100%;
      height: 40px;
    }
    .el-button {
      width: 100%;
      height: 40px;
      border-radius: 20px;
      background: #de2910;
      border: #de2910;
      margin: 20px 0px;
    }
    .login-content-code {
      width: 70%;
    }
    .login-content-code-img {
      width: 25%;
      background-color: #fff;
      border: 1px solid rgb(220, 223, 230);
      height: 38px;
      border-radius: 5px;
      margin-left: 4.5%;
      line-height: 38px;
      text-align: center;
      cursor: pointer;
    }
    .login-msg {
      margin-top: 30px;
      color: #a8abb2;
      font-size: 12px;
    }
  }
}

您好,我是肥晨。

欢迎关注我获取前端学习资源,日常分享技术变革,生存法则;行业内幕,洞察先机。

目录
相关文章
|
4月前
|
JavaScript 前端开发 安全
Vue 3
Vue 3以组合式API、Proxy响应式系统和全面TypeScript支持,重构前端开发范式。性能优化与生态协同并进,兼顾易用性与工程化,引领Web开发迈向高效、可维护的新纪元。(238字)
727 139
|
9月前
|
缓存 JavaScript PHP
斩获开发者口碑!SnowAdmin:基于 Vue3 的高颜值后台管理系统,3 步极速上手!
SnowAdmin 是一款基于 Vue3/TypeScript/Arco Design 的开源后台管理框架,以“清新优雅、开箱即用”为核心设计理念。提供角色权限精细化管理、多主题与暗黑模式切换、动态路由与页面缓存等功能,支持代码规范自动化校验及丰富组件库。通过模块化设计与前沿技术栈(Vite5/Pinia),显著提升开发效率,适合团队协作与长期维护。项目地址:[GitHub](https://github.com/WANG-Fan0912/SnowAdmin)。
1160 5
|
4月前
|
缓存 JavaScript 算法
Vue 3性能优化
Vue 3 通过 Proxy 和编译优化提升性能,但仍需遵循最佳实践。合理使用 v-if、key、computed,避免深度监听,利用懒加载与虚拟列表,结合打包优化,方可充分发挥其性能优势。(239字)
371 1
|
5月前
|
开发工具 iOS开发 MacOS
基于Vite7.1+Vue3+Pinia3+ArcoDesign网页版webos后台模板
最新版研发vite7+vue3.5+pinia3+arco-design仿macos/windows风格网页版OS系统Vite-Vue3-WebOS。
564 11
|
4月前
|
JavaScript 安全
vue3使用ts传参教程
Vue 3结合TypeScript实现组件传参,提升类型安全与开发效率。涵盖Props、Emits、v-model双向绑定及useAttrs透传属性,建议明确声明类型,保障代码质量。
441 0
|
6月前
|
缓存 前端开发 大数据
虚拟列表在Vue3中的具体应用场景有哪些?
虚拟列表在 Vue3 中通过仅渲染可视区域内容,显著提升大数据列表性能,适用于 ERP 表格、聊天界面、社交媒体、阅读器、日历及树形结构等场景,结合 `vue-virtual-scroller` 等工具可实现高效滚动与交互体验。
623 1
|
6月前
|
缓存 JavaScript UED
除了循环引用,Vue3还有哪些常见的性能优化技巧?
除了循环引用,Vue3还有哪些常见的性能优化技巧?
356 0
|
7月前
|
JavaScript
vue3循环引用自已实现
当渲染大量数据列表时,使用虚拟列表只渲染可视区域的内容,显著减少 DOM 节点数量。
169 0
|
9月前
|
JavaScript 前端开发 API
Vue 2 与 Vue 3 的区别:深度对比与迁移指南
Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,在过去的几年里,Vue 2 一直是前端开发中的重要工具。而 Vue 3 作为其升级版本,带来了许多显著的改进和新特性。在本文中,我们将深入比较 Vue 2 和 Vue 3 的主要区别,帮助开发者更好地理解这两个版本之间的变化,并提供迁移建议。 1. Vue 3 的新特性概述 Vue 3 引入了许多新特性,使得开发体验更加流畅、灵活。以下是 Vue 3 的一些关键改进: 1.1 Composition API Composition API 是 Vue 3 的核心新特性之一。它改变了 Vue 组件的代码结构,使得逻辑组
2073 0
|
5月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
485 2

热门文章

最新文章