一、效果展示
二、思路
使用多个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>
```