vue实现验证码输入框组件
内容摘要
这篇文章主要为大家详细介绍了vue实现验证码输入框组件,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
先来看波完成效果图
【512pic.com
对此感兴趣的朋友,看看idc笔记做的技术笔记!
先来看波完成效果图
【512pic.com
文章正文
这篇文章主要为大家详细介绍了vue实现验证码输入框组件,具有一定的参考价值,可以用来参考一下。
对此感兴趣的朋友,看看idc笔记做的技术笔记!
先来看波完成效果图
【512pic.com温馨提示:图片暂缺】
需求
输入4位或6位短信验证码,输入完成后收起键盘
实现步骤
第一步
布局排版
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 | <code> <div class = "security-code-wrap" > <label for = "code" > <ul class = "security-code-container" > <li class = "field-wrap" v- for = "(item, index) in number" :key= "index" > <i class = "char-field" >{{value[index] || placeholder}}</i> </li> </ul> </label> <input ref= "input" class = "input-code" @keyup= "handleInput($event)" v-model= "value" id= "code" name= "code" type= "tel" :maxlength= "number" autocorrect= "off" autocomplete= "off" autocapitalize= "off" > </div></code> |
使用li元素来模拟输入框的显示,没有别的目的,就只是为了语义化,当然你也可以使用其他任意一个元素来模拟,比如div。
使用label标签的好处在于它可以跟input的click事件关联上,一方面实现了语义化解决方案,另一方面也省去了我们通过js来唤起虚拟键盘。
隐藏输入框
代码如下:
1 2 3 4 5 6 7 8 9 10 11 | <code> .input-code { position: absolute; left: -9999px; top: -99999px; width: 0; height: 0; opacity: 0; overflow: visible; z-index: -1; }</code> |
将真实的输入框定位到屏幕可视区域以外的地方,虚拟键盘被唤起时,就不会将页面往上顶了。所以你的验证码输入组件一定要放在虚拟键盘遮挡不了的地方。
第二步
处理验证码输入
代码如下:
1 2 3 4 5 6 7 8 9 10 11 | <code> handleSubmit() { this. $emit ( 'input' , this.value) }, handleInput(e) { this. $refs .input.value = this.value if (this.value.length >= this.number) { this.hideKeyboard() } this.handleSubmit() }</code> |
输入时,给输入框赋一次值,是为了解决android端上输入框失焦后重新聚焦,输入光标会定在第一位的前面,经过赋值再聚焦,光标的位置就会显示在最后一位后面。
第三步
完成输入后关闭虚拟键盘
代码如下:
1 2 3 4 5 6 | <code> hideKeyboard() { // 输入完成隐藏键盘 document.activeElement.blur() // ios隐藏键盘 this. $refs .input.blur() // android隐藏键盘 }</code> |
组件完整代码
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 | <code> <!--四位验证码输入框组件--> <template> <div class = "security-code-wrap" > <label for = "code" > <ul class = "security-code-container" > <li class = "field-wrap" v- for = "(item, index) in number" :key= "index" > <i class = "char-field" >{{value[index] || placeholder}}</i> </li> </ul> </label> <input ref= "input" class = "input-code" @keyup= "handleInput($event)" v-model= "value" id= "code" name= "code" type= "tel" :maxlength= "number" autocorrect= "off" autocomplete= "off" autocapitalize= "off" > </div> </template> <script> export default { name: 'SecurityCode' , // component properties props: { number: { type: Number, default : 4 }, placeholder: { type: String, default : '-' } }, // variables data() { return { value: '' } }, methods: { hideKeyboard() { // 输入完成隐藏键盘 document.activeElement.blur() // ios隐藏键盘 this. $refs .input.blur() // android隐藏键盘 }, handleSubmit() { this. $emit ( 'input' , this.value) }, handleInput(e) { this. $refs .input.value = this.value if (this.value.length >= this.number) { this.hideKeyboard() } this.handleSubmit() } } } </script> <style scoped lang= "less" > .security-code-wrap { overflow: hidden; } .security-code-container { margin: 0; padding: 0; display: flex; justify-content: center; .field-wrap { list-style: none; display: block; width: 40px; height: 40px; line-height: 40px; font-size: 16px; background-color: #fff; margin: 2px; color: #000; .char-field { font-style: normal; } } } .input-code { position: absolute; left: -9999px; top: -99999px; width: 0; height: 0; opacity: 0; overflow: visible; z-index: -1; } </style></code> |
组件使用代码
代码如下:
1 2 | <code> <security-code v-model= "authCode" ></security-code></code> |
总结
以上所述是小编给大家介绍的vue实现验证码输入框组件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对php教程网站的支持!
注:关于vue实现验证码输入框组件的内容就先介绍到这里,更多相关文章的可以留意
代码注释