vue3制作类微信的六位的密码输入框

简介: vue3制作类微信的六位的密码输入框

这是一个 Vue 3 组件,用于创建一个自定义的密码输入框。这个输入框由6个小输入框组成,每个小输入框只能输入一个字符。当用户在一个小输入框中输入字符后,焦点会自动跳到下一个输入框,直到所有6个输入框都填满为止。当6个字符都输入完成后,会触发一个名为 'input-complete' 的自定义事件,并将输入的密码作为参数传递出去。

下面是代码的详细解释:

模板部分 (<template>)

  • <div class="password-input">: 包裹所有输入框的容器。
  • <input v-for="(item, index) in Array.from({ length: 6 })" :key="index" ref="inputs" v-model="passwords[index]" @input="onInput(index, $event)" maxlength="1" type="password" />: 使用 v-for 指令创建6个输入框。每个输入框绑定到 passwords 数组的一个元素上,并通过 @input 监听输入事件。
  • v-for="(item, index) in Array.from({ length: 6 })": 循环6次以创建6个输入框。
  • :key="index": 为每个输入框设置一个唯一的 key。
  • ref="inputs": 为所有输入框设置一个引用。
  • v-model="passwords[index]": 双向绑定到 passwords 数组的一个元素上。
  • @input="onInput(index, $event)": 当输入框的值改变时,调用 onInput 函数。
  • maxlength="1": 限制每个输入框只能输入一个字符。
  • type="password": 设置输入框类型为密码,这样输入的字符会被遮挡。

脚本部分 (<script setup>)

  • import { ref, onMounted, watch } from 'vue';: 从 Vue 3 中导入所需的函数和API。
  • const passwords = ref(Array(6).fill(''));: 创建一个响应式引用 passwords,初始化为一个包含6个空字符串的数组。
  • function onInput(index, event) {...}: 定义一个函数,当输入框的值改变时被调用。如果当前输入框不是最后一个(索引小于5),则使当前输入框失去焦点,并在下一个可用的输入框上设置焦点。
  • onMounted(() => {...}): 在组件挂载完成后执行一些操作。这里使用 watch 函数来监听 passwords 引用的变化。当 passwords 的值改变时,检查密码的长度是否达到6个字符,如果是,则触发 'input-complete' 事件。

样式部分 (<style scoped>)

  • .password-input input: 为 .password-input 类下的所有 input 元素设置样式。这里设置了宽度、高度、文本对齐方式和外边距。
  • scoped: 这个属性意味着这些样式只适用于当前组件,不会影响其他组件或全局样式
<template>
  <div class="password-input">
    <input v-for="(item, index) in Array.from({ length: 6 })" :key="index"
      ref="inputs" v-model="passwords[index]" @input="onInput(index, $event)" 
      maxlength="1" type="password" />
  </div>
</template>
<script setup>
import { ref, onMounted, watch } from 'vue';
const passwords = ref(Array(6).fill(''));
function onInput(index, event) {
  const input = event.target;
  if (!input.value) return;
  if (index < 5) {
    input.blur();
    setTimeout(() => {
      const nextIndex = index + 1;
      const nextInput = input.nextElementSibling;
      if (nextInput) nextInput.focus();
    }, 0);
  }
}
onMounted(() => {
  watch(passwords, (newVal) => {
    const password = newVal.join('');
    if (password.length === 6) {
      // 触发密码输入完成事件,传递密码值
      emit('input-complete', password);
    }
  });
});
</script>
<style scoped>
.password-input input {
  width: 40px;
  height: 40px;
  text-align: center;
  margin: 0 5px;
}
</style>
相关文章
|
6月前
|
数据安全/隐私保护
常用的表单校验规则——邮箱/QQ/身份证号码/微信/电话/数字字母/整数/文本/密码等
常用的表单校验规则——邮箱/QQ/身份证号码/微信/电话/数字字母/整数/文本/密码等
170 0
|
4月前
|
小程序 数据库
【微信小程序-原生开发】实用教程10 - 动态的新增、修改、删除(含微信云数据库的新增、修改、删除,表单弹窗、确认弹窗、日期选择器、单行输入框、多行输入框、滑动组件的使用)
【微信小程序-原生开发】实用教程10 - 动态的新增、修改、删除(含微信云数据库的新增、修改、删除,表单弹窗、确认弹窗、日期选择器、单行输入框、多行输入框、滑动组件的使用)
131 0
|
12月前
|
数据安全/隐私保护
常用的表单校验规则——邮箱/QQ/身份证号码/微信/电话/数字字母/整数/文本/密码等
常用的表单校验规则——邮箱/QQ/身份证号码/微信/电话/数字字母/整数/文本/密码等
128 0
|
3月前
|
存储 小程序 JavaScript
|
3月前
|
小程序 JavaScript
|
4月前
|
JSON 小程序 JavaScript
【微信小程序-原生开发】TDesign 实战模板——账号密码登录页(含密码显示隐藏的技巧)
【微信小程序-原生开发】TDesign 实战模板——账号密码登录页(含密码显示隐藏的技巧)
131 0
|
6月前
|
存储 小程序 JavaScript
微信小程序-----通用获取输入框的值
微信小程序-----通用获取输入框的值
|
6月前
|
小程序 前端开发 定位技术
微信小程序-常用的视图容器类组件
该内容是关于微信小程序组件的分类和部分具体组件的介绍。主要分为9大类:视图容器、基础内容、表单组件、导航组件、媒体组件、地图组件、画布组件、开放能力和无障碍访问。其中详细讲解了`view`、`scroll-view`、`swiper`及`swiper-item`等组件的用途和示例。`view`用于构建页面布局,`scroll-view`支持滚动效果,`swiper`则用于创建轮播图。此外,还提到了`root-portal`、`page-container`等其他特殊用途的组件。
76 0
|
6月前
|
小程序
微信小程序——如何获取到输入框的值
微信小程序——如何获取到输入框的值
1121 0
|
6月前
|
小程序 前端开发 定位技术
【微信小程序】-- 常用视图容器类组件介绍 -- view、scroll-view和swiper(六)
【微信小程序】-- 常用视图容器类组件介绍 -- view、scroll-view和swiper(六)

热门文章

最新文章