完美解决移动端 Input 获取焦点软键盘遮挡文本框元素方法

发布于 2019-03-07 10:21:55 字数 623 浏览 2474 评论 0

移动端 Input 文本框获取焦点后,会弹起软键盘输入,此时的窗口大小已发生改变,经过测试发现 iPhone 可以自动上滑页面,但是 Android 页面没有任何滑动。

HTML 5 有个函数可以实现页面滑动,Element.scrollIntoView() 方法让当前的元素滚动到浏览器窗口的可视区域内,于是就有了下面的方法。

window.addEventListener('resize', () => {
  const activeElement = document.activeElement
  if (activeElement.tagName === 'INPUT' ||
      activeElement.tagName === 'TEXTAREA') {
    setTimeout(() => {
      activeElement.scrollIntoView()
    }, 100)
  }
})

当 Window 窗口发生变化时候,获取当前的焦点元素(document.activeElement),然后使用 scrollIntoView 函数让当前的元素滚动到浏览器窗口的可视区域内。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

0 文章
0 评论
84961 人气
更多

推荐作者

醉城メ夜风

文章 0 评论 0

远昼

文章 0 评论 0

平生欢

文章 0 评论 0

微凉

文章 0 评论 0

Honwey

文章 0 评论 0

qq_ikhFfg

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文