解决 H5 IOS input 聚焦时,软键盘将页面整个推上去,键盘收起页面未下移 BUG

问题描述

近日在开发H5应用时,测试人员发现在IOS低版本中input,textArea等输入框聚焦时,软键盘弹起会将整个页面向上顶,收回键盘后,页面不会回弹恢复页面,导致页面下方产生大量空白。

解决方案

在页面中添加以下js即可解决:

// 解决 H5 IOS input 聚焦时,页面整个被推上去了,键盘收起页面未下移 BUG
$(function () {
	(/iphone|ipod|ipad/i.test(navigator.appVersion)) && document.addEventListener('blur', event => {
		// 当页面没出现滚动条时才执行,因为有滚动条时,不会出现这问题
	    // input textarea 标签才执行,因为 a 等标签也会触发 blur 事件
	    if (
	        document.documentElement.offsetHeight <=
	        document.documentElement.clientHeight &&
	        ['input', 'textarea'].includes(event.target.localName)
	    ) {
	        document.body.scrollIntoView() // 回顶部
	    }
	}, true);
});
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值