前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >多个input框自动切换焦点

多个input框自动切换焦点

作者头像
tianyawhl
发布2020-11-12 11:23:54
3.3K0
发布2020-11-12 11:23:54
举报
文章被收录于专栏:前端之攻略前端之攻略

使用Javascript可以从多个方面增强表单字段的易用性。其中,最常见的一种方式就是在用户填写完当前字段时,自动将焦点切换到下一个字段,必须知道用户已经输入了既定长度的数据(例如电话号码),输入一个后焦点切换到下一个输入框

代码语言:javascript
复制
    <!-- 自动切换焦点 -->
    <div id="telWrap">
      <input type="text" name="tel1" id="txtTel1" maxlength="3">
      <input type="text" name="tel2" id="txtTel2" maxlength="3">
      <input type="text" name="tel3" id="txtTel3" maxlength="4">
    </div>
代码语言:javascript
复制
  var textbox1 = document.getElementById("txtTel1")
  var textbox2 = document.getElementById("txtTel2")
  var textbox3 = document.getElementById("txtTel3")
  document.addEventListener("keyup",tabForward) // 使用事件代理,也可用下面的
  // textbox1.addEventListener("keyup",tabForward)
  // textbox2.addEventListener("keyup",tabForward)
  // textbox3.addEventListener("keyup",tabForward)
  function tabForward(event){
    var target = event.target
    if(target.value.length == target.maxLength){  // 注意不是maxlength
      var elements = document.getElementById("telWrap").getElementsByTagName("input")
      for(let i=0;i<elements.length;i++) {
        if(elements[i] == target){
          if(elements[i+1]){
            elements[i+1].focus()
          }
          return  // 退出当前函数
        }
      }
    }
  }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档