Vue Steam同款登录验证数字输入框功能

 更新时间:2024年03月13日 14:49:34   作者:一天只码五十行  
这篇文章主要介绍了Vue Steam同款登录验证数字输入框功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

一、效果展示

二、思路

使用多个Input,在输入和回撤时改变焦点

三、代码

<template>
  <div class="page">
    <div class="mainBox">
      <div class="numberBox">
        <div class="inputBox" v-for="(item, index) in 5" :key="index">
          <input
            :ref="(el) => { if (el) setupRefs[index] = el as HTMLInputElement; }"
            type="text"
            maxlength="1"
            v-model.number="counts[index - 1]"
            @input="onInputChange(index, $event as InputEvent)"
            @keydown="handleKeyDown(index, $event)"
          />
        </div>
      </div>
      <div class="bottomBox">
        <div class="textBox">
          输入您电子邮件地址<span style="color: #2386f5">qq.com</span
          >中获得的代码
        </div>
        <div class="image"></div>
      </div>
    </div>
  </div>
</template>
<script setup lang="ts">
import { ref } from "vue";
// 用于存储输入框的值
const counts = ref(Array(5).fill(undefined));
// 获取输入框dom
const setupRefs = ref<Array<HTMLInputElement | null>>(new Array(5).fill(null));
// 输入框的值发生变化时
const onInputChange = (currentIndex: number, event: InputEvent) => {
  const value = (event.target as HTMLInputElement).value;
  if (value && isNaN(Number(value))) {
    // 如果输入的不是数字,则清空输入框
    (event.target as HTMLInputElement).value = "";
  } else if (value && value !== "") {
    setTimeout(() => {
      setupRefs.value[currentIndex + 1]?.focus();
    }, 0);
  }
};
// 输入框按下键盘时
const handleKeyDown = (currentIndex: number, event: KeyboardEvent) => {
  if (event.key === "Backspace" && !counts.value[currentIndex - 1]) {
    event.preventDefault(); // 阻止默认行为(删除字符)
    setupRefs.value[currentIndex - 1]?.focus();
  }
};
</script>
<style lang="scss">
.page {
  width: 100%;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #191a1e;
  .mainBox {
    width: 700px;
    height: 300px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 5px;
    background-color: #32353c;
    flex-direction: column;
    .numberBox {
      width: auto;
      height: 100px;
      padding: 0 40px;
      display: flex;
      justify-content: center;
      align-items: center;
      border-radius: 5px;
      background-color: #2b2e33;
      padding-bottom: 15px;
      input {
        margin-left: 35px;
        width: 60px;
        height: 60px;
        text-align: center;
        font-size: 25px;
        background-color: #32353c;
        color: #fff;
        border: none; /* 设置所有边框的样式为none */
        border-bottom: 3px solid #4c4e52; /* 单独设置底部边框 */
        background-color: #2b2e33;
        outline: none;
      }
      input[type="number"]::-webkit-inner-spin-button,
      input[type="number"]::-webkit-outer-spin-button {
        -webkit-appearance: none;
      }
    }
    .bottomBox {
      display: flex;
      margin-top: 15px;
      .textBox {
        width: auto;
        height: 100px;
        font-size: 24px;
        background-color: #32353c;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
      }
      .image {
        width: 100px;
        height: 100px;
        margin-left: 40px;
        background: url("");
        background-size: 100% 100%;
      }
    }
  }
}
</style>
```

到此这篇关于Vue Steam同款登录验证数字输入框的文章就介绍到这了,更多相关vue验证数字输入框内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解Vue3的七种组件通信方式

    详解Vue3的七种组件通信方式

    本篇文章将详解介绍Vue3中如下七种组件通信方式:props、emit、v-model、refs、provide/inject、eventBus、vuex/pinia(状态管理工具)。感兴趣的可以了解一下
    2022-02-02
  • vue3实现手机上可拖拽元素的组件

    vue3实现手机上可拖拽元素的组件

    这篇文章主要介绍了vue3实现手机上可拖拽元素的组件,用vue3实现一个可在手机上拖拽元素的组件,可拖拽至任意位置,并且可以防止拖拽元素移出屏幕边缘
    2022-09-09
  • VUE项目中加载已保存的笔记实例方法

    VUE项目中加载已保存的笔记实例方法

    在本篇文章里小编给大家整理了一篇关于VUE项目中加载已保存的笔记实例方法,有兴趣的读者们可以参考下。
    2019-09-09
  • 基于Vue实现拖拽效果

    基于Vue实现拖拽效果

    这篇文章主要介绍了基于Vue实现拖拽效果,文中给大家介绍了clientY pageY screenY layerY offsetY的区别讲解,需要的朋友可以参考下
    2018-04-04
  • vue3.0-monaco组件封装存档代码解析

    vue3.0-monaco组件封装存档代码解析

    这篇文章主要介绍了vue3.0-monaco组件封装存档代码解析,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-03-03
  • 项目部署后前端vue代理失效问题解决办法

    项目部署后前端vue代理失效问题解决办法

    这篇文章主要给大家介绍了关于项目部署后前端vue代理失效问题的解决办法,文中通过图文以及代码示例将解决的办法介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-02-02
  • vue 动态添加的路由页面刷新时失效的原因及解决方案

    vue 动态添加的路由页面刷新时失效的原因及解决方案

    这篇文章主要介绍了vue动态添加的路由页面刷新时失效的原因及解决方案,帮助大家更好的理解和学习使用vue,感兴趣的朋友可以了解下
    2021-02-02
  • Vue中消息横向滚动时setInterval清不掉的问题及解决方法

    Vue中消息横向滚动时setInterval清不掉的问题及解决方法

    最近在做项目时,需要进行两个组件联动,一个轮询获取到消息,然后将其传递给另外一个组件进行横向滚动展示,结果滚动的速度越来越快。接下来通过本文给大家分享Vue中消息横向滚动时setInterval清不掉的问题及解决方法,感兴趣的朋友一起看看吧
    2019-08-08
  • vue3 头像上传 组件功能实现

    vue3 头像上传 组件功能实现

    这篇文章主要介绍了vue3头像上传组件功能,用到了自定义组件v-model的双向绑定,使用axios + formData 上传文件,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • 深入解析el-col-group强大且灵活的Element表格列组件

    深入解析el-col-group强大且灵活的Element表格列组件

    这篇文章主要为大家介绍了el-col-group强大且灵活的Element表格列组件深入解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04

最新评论