找回密码
 立即注册
查看: 85|回复: 0

16,注册页面

[复制链接]

282

主题

6

精华

286

金币

技术维护QQ:515138

积分
615
发表于 2026-3-5 14:47:14 | 显示全部楼层 |阅读模式
1.jpg

  1. <scrip t setup>
  2. import { User, Lock } from '@element-plus/icons-vue'
  3. import { ref } from 'vue'
  4. //控制注册与登录表单的显示, 默认显示注册
  5. const isRegister = ref(false)
  6. // 定义数据模型
  7. const registerData = ref({
  8.   username: '',
  9.   password: '',
  10.   repassword: ''
  11. })
  12. //校验密码的函数
  13. const checkRePassword = (rule, value, callback) => {
  14.     if (value === '') {
  15.         callback(new Error('请再次确认密码'))
  16.     } else if (value !== registerData.value.password) {
  17.         callback(new Error('请确保两次输入的密码一样'))
  18.     } else {
  19.         callback()  // 校验通过
  20.     }
  21. }
  22. //定义表单校验规则
  23. const rules = {
  24.     username: [
  25.         { required: true, message: '请输入用户名', trigger: 'blur' },
  26.         { min: 5, max: 16, message: '长度为5~16位非空字符', trigger: 'blur' }
  27.     ],
  28.     password: [
  29.         { required: true, message: '请输入密码', trigger: 'blur' },
  30.         { min: 5, max: 16, message: '长度为5~16位非空字符', trigger: 'blur' }
  31.     ],
  32.     repassword: [
  33.         { validator: checkRePassword, trigger: 'blur' }
  34.     ]
  35. }
  36. </script>
  37. <template>
  38.     <el-row class="login-page">
  39.         <el-col :span="12" class="bg"></el-col>
  40.         <el-col :span="6" :offset="3" class="form">
  41.             <!-- 注册表单 -->
  42.             <el-form ref="form" size="large" autocomplete="off" v-if="isRegister" :model="registerData" :rules="rules">
  43.                 <el-form-item>
  44.                     <h1>注册</h1>
  45.                 </el-form-item>
  46.                 <el-form-item prop="username">
  47.                     <el-input :prefix-icon="User" placeholder="请输入用户名" v-model="registerData.username"></el-input>
  48.                 </el-form-item>
  49.                 <el-form-item prop="password">
  50.                     <el-input :prefix-icon="Lock" type="password" placeholder="请输入密码" v-model="registerData.password"></el-input>
  51.                 </el-form-item>
  52.                 <el-form-item prop="repassword">
  53.                     <el-input :prefix-icon="Lock" type="password" placeholder="请输入再次密码" v-model="registerData.repassword"></el-input>
  54.                 </el-form-item>
  55.                 <!-- 注册按钮 -->
  56.                 <el-form-item>
  57.                     <el-button class="button" type="primary" auto-insert-space>
  58.                         注册
  59.                     </el-button>
  60.                 </el-form-item>
  61.                 <el-form-item class="flex">
  62.                     <el-link type="info" :underline="false" @click="isRegister = false">
  63.                         ← 返回
  64.                     </el-link>
  65.                 </el-form-item>
  66.             </el-form>
  67.             <!-- 登录表单 -->
  68.             <el-form ref="form" size="large" autocomplete="off" v-else>
  69.                 <el-form-item>
  70.                     <h1>登录</h1>
  71.                 </el-form-item>
  72.                 <el-form-item>
  73.                     <el-input :prefix-icon="User" placeholder="请输入用户名"></el-input>
  74.                 </el-form-item>
  75.                 <el-form-item>
  76.                     <el-input name="password" :prefix-icon="Lock" type="password" placeholder="请输入密码"></el-input>
  77.                 </el-form-item>
  78.                 <el-form-item class="flex">
  79.                     <div class="flex">
  80.                         <el-checkbox>记住我</el-checkbox>
  81.                         <el-link type="primary" :underline="false">忘记密码?</el-link>
  82.                     </div>
  83.                 </el-form-item>
  84.                 <!-- 登录按钮 -->
  85.                 <el-form-item>
  86.                     <el-button class="button" type="primary" auto-insert-space>登录</el-button>
  87.                 </el-form-item>
  88.                 <el-form-item class="flex">
  89.                     <el-link type="info" :underline="false" @click="isRegister = true">
  90.                         注册 →
  91.                     </el-link>
  92.                 </el-form-item>
  93.             </el-form>
  94.         </el-col>
  95.     </el-row>
  96. </template>
  97. <style lang="scss" scoped>
  98. /* 样式 */
  99. .login-page {
  100.     height: 100vh;
  101.     background-color: #fff;
  102.     .bg {
  103.         background: url('@/assets/logo2.png') no-repeat 60% center / 240px auto,
  104.             url('@/assets/login_bg.jpg') no-repeat center / cover;
  105.         border-radius: 0 20px 20px 0;
  106.     }
  107.     .form {
  108.         display: flex;
  109.         flex-direction: column;
  110.         justify-content: center;
  111.         user-select: none;
  112.         .title {
  113.             margin: 0 auto;
  114.         }
  115.         .button {
  116.             width: 100%;
  117.         }
  118.         .flex {
  119.             width: 100%;
  120.             display: flex;
  121.             justify-content: space-between;
  122.         }
  123.     }
  124. }
  125. </style>
复制代码





上一篇:15,大事件前端开发准备工作
下一篇:17,user参数传递,借助于UrlSearchParams完成传递
网站建设,公众号小程序开发,系统定制,软件App开发,技术维护【联系我们】手机/微信:17817817816 QQ:515138

QQ|Archiver|自丢网 ( 粤ICP备2024252464号-1 )

GMT+8, 2026-3-23 06:29

专注于网站建设,公众号小程序制作,商城小程序,系统定制,软件App开发

【联系我们】手机/微信:17817817816 QQ:515138

快速回复 返回顶部 返回列表