利用vue实现密码输入框/验证码输入框
更新时间:2023年08月30日 15:11:19 作者:前端61
这篇文章主要为大家详细介绍了如何利用vue实现密码输入框或验证码输入框的效果,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下
1.效果预览
2.实现思路
制作6个小的正方形div
用一个input覆盖在6个div上
给input设置透明(隐藏掉input)
3.源码
html
<div class="input-box flexbox"> <div class="code-item" :class="codeValue.length == 0 && inputFocus ? 'code-item-active' : ''">{{codeValue[0]}}</div> <div class="code-item" :class="codeValue.length == 1 && inputFocus ? 'code-item-active' : ''">{{codeValue[1]}}</div> <div class="code-item" :class="codeValue.length == 2 && inputFocus ? 'code-item-active' : ''">{{codeValue[2]}}</div> <div class="code-item" :class="codeValue.length == 3 && inputFocus ? 'code-item-active' : ''">{{codeValue[3]}}</div> <div class="code-item" :class="codeValue.length == 4 && inputFocus ? 'code-item-active' : ''">{{codeValue[4]}}</div> <div class="code-item" :class="codeValue.length >= 5 && inputFocus ? 'code-item-active' : ''">{{codeValue[5]}}</div> <el-input class="input-code" :value="codeValue" :maxlength="6" @blur="codeInputBlur" @focus="codeInputFocus" @input="codeInputChange"> </el-input> </div>
css
.input-box { margin-top: 20px; position: relative; } .input-code { position: absolute; } .code-item { width: 50px; height: 50px; text-align: center; line-height: 50px; border: 1px solid #f0f0f0; margin-right: 10px; } .code-item-active { border: 1px solid #F23026; box-sizing: border-box; } // 隐藏input .input-box { .el-input__inner { width: 362px; height: 50px; background-color: transparent; border: none; color: transparent; } }
js
data() { return { codeValue: '', inputFocus: false, sendCodeFlag: false, codeTime: 59, }; }, methods: { // 发送验证码 sendCode() { this.codeTime = 59; this.sendCodeFlag = true; const timer = setInterval(() => { this.codeTime -= 1; if (this.codeTime <= 0) { this.sendCodeFlag = false; clearInterval(timer); } }, 1000); }, // 验证码输入框 codeInputChange(e) { if (e) { // 判断输入内容是否为数字 if ((/^\+?[0-9][0-9]*$/).test(e)) { this.codeValue = e; } } else { this.codeValue = ''; } }, // 验证码输入框失去焦点 codeInputBlur() { this.inputFocus = false; }, // 验证码输入框获取到焦点 codeInputFocus() { this.inputFocus = true; }, },
到此这篇关于利用vue实现密码输入框/验证码输入框的文章就介绍到这了,更多相关vue输入框内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue路由第二次进入页面created和mounted不执行问题及解决
这篇文章主要介绍了vue路由第二次进入页面created和mounted不执行问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-12-12vue+elementUI 复杂表单的验证、数据提交方案问题
这篇文章主要介绍了vue+elementUI 复杂表单的验证、数据提交方案,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-06-06vue中实现点击按钮滚动到页面对应位置的方法(使用c3平滑属性实现)
这篇文章主要介绍了vue中实现点击按钮滚动到页面对应位置的方法,这段代码主要使用c3平滑属性实现,需要的朋友可以参考下2019-12-12详解vue3.2新增的defineCustomElement底层原理
本文主要介绍了vue3.2新增的defineCustomElement底层原理,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2021-08-08
最新评论