抽象步骤条(2.0版本)

news2024/12/27 13:50:54

vue3 + router + ele-plus

猜猜看为什么使用组件库!

他呀的!查看密码要自己写,验证信息也要自己写,所以说会用组件库会轻松一点,,,

代码如下

<template>
  <div class="main">
    <div class="steps">
      <ol>
        <li
            v-for="(step, index) in steps"
            :key="index"
            :class="{ active: currentIndex === index, done: currentIndex > index }"
        >
          {{ step }}
        </li>
      </ol>
    </div>
    <el-form :model="form" :rules="rules" class="step-content">
      <div v-if="currentIndex === 0">
        <h3>请填写您需要找回密码的账号</h3>
        <el-form-item class="step-content-button" label="账号:" prop="username">
          <el-input  v-model="form.username" type="text" required/>
        </el-form-item>

      </div>
      <div v-else-if="currentIndex === 1">
        <h3>请填写您的完整邮箱</h3>
        <el-form-item class="step-content-button" label="邮箱:" prop="email">
          <el-input v-model="form.email" type="email" required/>
        </el-form-item>

      </div>
      <div v-else-if="currentIndex === 2">
        <h3>请输入您收到的验证码进行校验</h3>
        <el-form-item class="step-content-button" label="验证码:" prop="code">
          <el-row :gutter="10">
            <el-col :span="17">
              <el-input v-model="form.code"></el-input>
            </el-col>
            <el-col :span="5">
              <el-button type="primary">发送验证码</el-button>
            </el-col>
          </el-row>
        </el-form-item>
      </div>
      <div v-else-if="currentIndex === 3">
        <h3>请输入您的新密码进行重置。</h3>
        <el-form-item class="step-content-button" label="新密码:" prop="password">
          <el-input v-model="form.password" type="password" required placeholder="新密码" show-password/>
        </el-form-item>
        <el-form-item label="确认新密码:" prop="password_repeat">
          <el-input v-model="form.password_repeat" type="password" required placeholder="确认新密码" show-password/>
        </el-form-item>

      </div>
    </el-form>
    <div class="step-button">
      <el-button @click="prevStep" :disabled="currentIndex === 0">上一步</el-button>
      <el-button v-if="currentIndex === 0" type="primary" @click="nextStep">下一步</el-button>
      <el-button v-if="currentIndex === 1" type="primary" @click="nextStep">下一步</el-button>
      <el-button v-if="currentIndex === 2" type="primary" @click="nextStep">下一步</el-button>
      <el-button v-if="currentIndex === 3" type="primary" @click="nextStep">修改密码</el-button>
    </div>
  </div>
</template>

<script setup>
import {reactive, ref} from 'vue';

//可直接使用ele-plus中的步骤条代替!!!!!!
const steps = ['找回账号', '身份校验', '验证码校验', '密码重置'];
const currentIndex = ref(0);
// 定义一个 'nextStep' 函数,用于切换到下一个步骤
const nextStep = () => {
  if (currentIndex.value < steps.length - 1) {
    currentIndex.value++;
  }
};
// 定义一个 'prevStep' 函数,用于切换到上一个步骤
const prevStep = () => {
  if (currentIndex.value > 0) {
    currentIndex.value--;
  }
};


const form = reactive({
  username: '',
  password: '',
  password_repeat: '',
  email: '',
  code: ''
})


const validateUsername = (rule, value, callback) => {
  if (value === '') {
    callback(new Error('请输入用户名'))
  } else if(!/^[a-zA-Z0-9_]+$/.test(value)){
    callback(new Error('用户名由下划线,数字,字母组成'))
  } else {
    callback()
  }
}

const validatePassword = (rule, value, callback) => {
  if (value === '') {
    callback(new Error('请再次输入密码'))
  } else if (value !== form.password) {
    callback(new Error("两次输入的密码不一致"))
  } else {
    callback()
  }
}

const rules = {
  username: [
    { validator: validateUsername, trigger: ['blur', 'change'] },
    { min: 12, max: 16, message: '用户名的长度必须在12-16个字符之间', trigger: ['blur', 'change'] },
  ],
  password: [
    { message: '请输入密码', trigger: 'blur' },
    { min: 12,  message: '密码的长度最低为12字符', trigger: ['blur', 'change'] }
  ],
  password_repeat: [
    { validator: validatePassword, trigger: ['blur', 'change'] },
  ],
  email: [
    { message: '请输入邮件地址', trigger: 'blur' },
    {type: 'email', message: '请输入合法的电子邮件地址', trigger: ['blur', 'change']}
  ],
  code: [
    { message: '请输入获取的验证码', trigger: 'blur' },
  ]
}
</script>

<style scoped>
*{
  padding: 0;
  margin: 0;
}
/**/
.main{
  display: flex;
  flex-direction: column;
  align-items: center;
}

.step-content{
  margin-top: 10vh; /* 与步骤条的垂直距离 */
  text-align: center; /* 水平居中文本 */
}

.step-content-button{
  margin-top: 5vh; /* 与步骤条的垂直距离 */
}

.step-button{
  margin-top: 2vh;
}

/* step步骤条核心样式 */
.steps ol {
  --normal-color: #fff;  /* css变量,默认颜色  */
  --active-color: #428aea;  /* css变量,激活颜色  */

  display: flex;
  width: 70vw;
  margin-top: 15%; /* 调整步骤条垂直位置 */
  justify-content: space-between;
  counter-reset: order;  /* 定义CSS计数器 */
}

  /* 步骤项 */
.steps ol > li {
  flex: auto;
  display: inline-flex;
  align-items: center;
  counter-increment: order;
  color: var(--active-color);
}

/* 去掉右边多余 */
.steps ol > li:last-child {flex: none;}

  /* 步骤编号(带圈数字) */
.steps ol> li::before {
  content: counter(order);
  flex-shrink: 0;
  width: 1.4em;
  line-height: 1.4em;
  margin-right: .5em;
  text-align: center;
  border-radius: 50%;
  border: 1px solid;
}

  /* 步骤项引导线 */
.steps ol> li:not(:last-child)::after {
  content: '';
  flex: 1;
  margin: 0 1em;
  border-bottom: 1px solid;
  opacity: .6;
}
  /* 步骤状态 */
.steps ol> .active {color: var(--active-color);}
.steps ol> .active::before {
  color: #fff;
  background: var(--active-color);
  border-color: var(--active-color);
}
.steps ol> .active::after,
.steps ol> .active ~ li {color: var(--normal-color);}
</style>

下个版本预告,

在点击下一步时,步骤条的数字会变成一个绿色的勾,添加微动画,添加更多的注释

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1489677.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

自动化构建平台(五)之Jenkins初始化配置以及插件安装操作

文章目录 前言一、安装必要插件二、系统参数配置三、全局工具配置总结 前言 上一篇我们介绍了Jenkins的安装和登录等相关操作&#xff0c;今天给大家介绍登录Jenkins后的一些初始化配置和插件安装的操作。因为如果要使用Jenkins来进行代码构建&#xff0c;必须先安装相关的插件…

WebDAV之π-Disk派盘+人生Life

人生Life是一款日程软件,在这款待办的日程软件当中各种功能极为的完善,完全的足够用户在日常当中的使用,你的待办方面的各种内容都能够在软件上面进行规划和填充,通过待办事项来帮助用户提高在日常当中的效率,对于用户来说这款待办事项的软件是绝佳的选择。 π-Disk派盘 …

VScode---php环境搭建

文章目录 1.下载php Dehug;php server2.下载php环境3.配置环境变量5.配置php.ini文件6.设置vscode6.测试遇到的问题 1.下载php Dehug;php server 2.下载php环境 下载地址&#xff1a;https://www.php.net/downloads.php 3.配置环境变量 C:\Users\hacker>php -v PHP 8.3.3 (…

c++编程复习之字符数组:电报文字

电报文字 内存限制&#xff1a;128Mb 时间限制&#xff1a;1000s 提交&#xff1a;138 解决&#xff1a;13 题目描述 输入一行电报文字&#xff0c;将字母变成其下一字母&#xff08;如’aa’变成’bb’……’zz’变成’&#xff41;&#xff41;’其它字符不变&#xff09;。 …

【leetcode】随机链表的复制

大家好&#xff0c;我是苏貝&#xff0c;本篇博客带大家刷题&#xff0c;如果你觉得我写的还不错的话&#xff0c;可以给我一个赞&#x1f44d;吗&#xff0c;感谢❤️ 点击查看题目 思路: struct Node* copyRandomList(struct Node* head) {struct Node* curhead;//1.copy原链…

温湿度传感器SHT21

SHT21是一款基于IIC的温湿度传感器&#xff0c;它的引脚及定义如下&#xff1a; 标准的IIC器件&#xff0c;没有其他多余的引脚&#xff0c;应用框图如下&#xff1a; 温度的测量范围是-40到125℃&#xff0c;湿度测量范围0-100%RH&#xff0c;具体参数及采样精度见下图&#x…

利用excel文件增量同步一个库的数据并自动校正两端数据库条数不一致

利用excel文件增量同步一个库的数据并自动校正两端数据库条数不一致 现在有sqlserver和mysql两个库上的表在进行同步&#xff0c;sqlserver上的是源表&#xff0c;mysql上是目标表。 我们就把sqlserver上的数据同步到mysql上 mysql 是没有数据的。 sqlserver的三个表只是创建了…

Java-集合/容器

集合的概念 当我们需要保存一组一样&#xff08;类型相同&#xff09;的元素的时候&#xff0c;我们应该使用一个容器来存储&#xff0c;数组就是这样一个容器。 数组的特点&#xff1a; 数组是一组数据类型相同的元素集合&#xff1b; 创建数组时&#xff0c;必须给定…

Rabbitmq消息丢失-生产者消息丢失(一)

说明&#xff1a;消息生产者在将数据发送到Mq的时候&#xff0c;可能由于网络等原因造成数据投递失败。 消息丢失大致分三种&#xff1a;这里说的是生产者消息丢失&#xff01; 分析原因&#xff1a; 1.有没有一种可能&#xff0c;我刚发送消息&#xff0c;消息还没有到交换…

Matlab|配电网智能软开关(sop)规划模型

目录 1 主要内容 目标函数 2 部分程序 3 程序结果 3.1 sop选址定容优化模型 3.2 对比算例&#xff08;不含sop&#xff09; 4 下载链接 1 主要内容 该程序参考文献《基于改进灵敏度分析的有源配电网智能软开关优化配置》&#xff0c;采用二阶锥算法&#xff0c;以改进的…

Vue3+element-plus复杂表单分组处理

一、为什么表单要分组处理&#xff1f; 方便表单字段的复用&#xff1a;例如&#xff0c;你的表单有十个字段会在很多的表单都会用到&#xff0c;那么表单则需要进行分组进行表单复用&#xff1b;实现不同角色的表单权限控制&#xff1a;例如一个表单有60个字段&#xff0c;角…

STM32 NAND FLASH知识点

1.NAND FLASH的简介 NAND FLASH 的概念是由东芝公司在 1989 年率先提出&#xff0c;它内部采用非线性宏单元模式&#xff0c;为固态大容量内存的实现提供了廉价有效的解决方案。 NAND FLASH 存储器具有容量较大&#xff0c;改写速度快等优点&#xff0c;适用于大量数据的存储&…

【MySQL】事务、锁

目录 事务案例场景模拟实现转账&#xff1a;从张三的账户转账500元到李四的账户SQL示例异常 什么是事务事务的特性&#xff0c;简称ACID 属性实现原理redo logundo log MySQL 中一条 SQL 更新语句的执行过程( InnoDB 存储引擎)事务的提交流程隔离性并发事务产生的问题事务隔离级…

434G数据失窃!亚信安全发布《勒索家族和勒索事件监控报告》

最新态势快速感知 最新一周全球共监测到勒索事件90起&#xff0c;与上周相比数量有所增加。 lockbit3.0仍然是影响最严重的勒索家族&#xff1b;alphv和cactus恶意家族也是两个活动频繁的恶意家族&#xff0c;需要注意防范。 Change Healthcare - Optum - UnitedHealth遭受了…

【Python】外网远程登录访问jupyter notebook+pycharm使用ipython

第一步&#xff1a;创建python虚拟环境 conda create -n py3610 python3.6.10第二步&#xff1a;安装ipython pip install ipython pip install ipython notebook第三步&#xff1a;创建 IPython Notebook 服务器配置文件 # 进入python交互shell&#xff0c;设置密码 >&…

SpringCloud(19)之Skywalking应用上篇

一、Skywalking概述 随着互联网架构的扩张&#xff0c;分布式系统变得日趋复杂&#xff0c;越来越多的组件开始走向分布式化&#xff0c;如微服务、消 息收发、分布式数据库、分布式缓存、分布式对象存储、跨域调用&#xff0c;这些组件共同构成了繁杂的分布式网络。 思考以下…

Leaflet 加载高德地图

前言 在前面的文章中&#xff0c;我们学习了如何使用 Leaflet 创建一个基本的地图。在本文中&#xff0c;我们将学习如何在 Leaflet 中加载高德地图&#xff0c;并结合实际应用构建地图点击事件。 一、介绍 高德地图是一款由高德软件提供的数字地图服务&#xff0c;在国内使用…

在国内如何申请US,visa卡?

随着跨境与AI的发展大家对美国虚拟卡的需求也越来越多&#xff0c;比如说亚马逊、ebay、Etsy、ChatGPTPLUS、midjourney、POE等等软件以及海淘的需要&#xff0c;所以我们需要用到美国虚拟卡的场景就越来越多 如何获得一张US 虚拟信用卡&#xff1f; 方法很简单&#xff0c;点…

React-子传父

1.概念 说明&#xff1a;React中子组件向父组件传递数据通常涉及回调函数和状态提升等方法。 2.代码实现 2.1绑定事件 说明&#xff1a;父组件绑定自定义事件 <Son onGetSonMsg{getMsg}></Son> 2.2接受事件 说明&#xff1a;子组件接受父组件的自定义事件名称…

【Spring云原生】Spring Batch:海量数据高并发任务处理!数据处理纵享新丝滑!事务管理机制+并行处理+实例应用讲解

&#x1f389;&#x1f389;欢迎光临&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;特别推荐给大家我的最新专栏《Spring 狂野之旅&#xff1a;从入门到入魔》 &#x1f680; 本…