Vue?Steam同款登錄驗證數(shù)字輸入框功能
更新時間:2024年03月13日 14:49:34 作者:一天只碼五十行
這篇文章主要介紹了Vue?Steam同款登錄驗證數(shù)字輸入框功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
一、效果展示
二、思路
使用多個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)); // 輸入框的值發(fā)生變化時 const onInputChange = (currentIndex: number, event: InputEvent) => { const value = (event.target as HTMLInputElement).value; if (value && isNaN(Number(value))) { // 如果輸入的不是數(shù)字,則清空輸入框 (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; /* 設(shè)置所有邊框的樣式為none */ border-bottom: 3px solid #4c4e52; /* 單獨設(shè)置底部邊框 */ 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> ```
到此這篇關(guān)于Vue Steam同款登錄驗證數(shù)字輸入框的文章就介紹到這了,更多相關(guān)vue驗證數(shù)字輸入框內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決vue數(shù)據(jù)不實時更新的問題(數(shù)據(jù)更改了,但數(shù)據(jù)不實時更新)
這篇文章主要介紹了解決vue數(shù)據(jù)不實時更新的問題(數(shù)據(jù)更改了,但數(shù)據(jù)不實時更新),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10Vue3.0 響應(yīng)式系統(tǒng)源碼逐行分析講解
這篇文章主要介紹了Vue3.0 響應(yīng)式系統(tǒng)源碼逐行分析講解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-10-10解決Vue + Echarts 使用markLine標線(precision精度問題)
這篇文章主要介紹了解決Vue + Echarts 使用markLine標線(precision精度問題),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07