摘要:在系统中,当键盘弹起的时候,会挤压页面,评论框会自然在顶部,但是有个问题就是,下面的评论框会不贴底,露出下面的东西,所以在之前的解决办法就是在评论框触发的时候让页面滚动到底部,代码如下如果输入框失去焦点,就让页面滚动到先前的位置。
结构如下
我们需要做的就是当聚焦评论框的时候,ios需要让键盘顶起评论框。在ios系统中,当键盘弹起的时候,会挤压页面,评论框会自然在顶部,但是有个问题就是,下面的评论框会不贴底,露出下面的东西,所以在ios12之前的解决办法就是在评论框触发focus的时候让页面滚动到底部,代码如下:
const body = document.dcumentElement.scrollTop ? document.documentELement : document.body; const {scrollHeight, scrollTop} = body; const innerHeight = Math.min(window.innerHeight, document.documentElement.clientHeight); body.scrollTop = scrollHeight - innerHeight;
如果输入框失去焦点,就让页面滚动到先前的位置。
代码如下:
body.scrollTop = scrollTop; // 滚动到先前的位置
这种方案在ios12上会出现两个问题:
然后我自己分析了一下这个问题,出现各种情况的原因是因为弹出键盘时,页面能够滚动,于是就出现了各种问题,那干脆让页面无法滚动。ios11及之前使用了下面的布局:
.parent { position: fixed; left: 0; right: 0; bottom: 0; top: 0; }
并且禁止了touchmove事件,这样能够让页面无法滚动,但是ios12并没有什么卵用。还是能够滚动,那咱们就让内容就一屏,多的被截掉。下面是输入框focus的代码:
const {scrollHeight,scrollTop} = body; const innerHeight = Math.min(window.innerHeight, document.documentElement.clientHeight); body.style.height = `${innerHeight}px`; body.style.overflow = "hidden";
然后就是输入框触发blur事件时的代码:
body.style.height = `${scrollHeight}px`; body.style.overflow = "auto"; body.style.scrollTop = scrollTop;
在这里需要重新设置body的高度,高度为之前获取的scrollHeight,因为我们需要重新滚动到先前的位置,建议不要设置height为auto,因为在一些场景下我们可能需要监听滚动事件,会出现其他的问题(稳战稳打才能打胜仗)。然后重新设置body的overflow,让页面能够滚动,最后滚动到先前的位置。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/101910.html
摘要:在系统中,当键盘弹起的时候,会挤压页面,评论框会自然在顶部,但是有个问题就是,下面的评论框会不贴底,露出下面的东西,所以在之前的解决办法就是在评论框触发的时候让页面滚动到底部,代码如下如果输入框失去焦点,就让页面滚动到先前的位置。 结构如下showImg(https://segmentfault.com/img/remote/1460000018217892?w=640&h=960);...
摘要:在之后,的框失焦后页面会出现被顶上去一部分的下面就来看下怎么解决这个,首先我们必须知道这两个方法软键盘弹起事件软键盘关闭事件。 在iOS12之后,h5的input框失焦后页面会出现被顶上去一部分的bug,下面就来看下怎么解决这个bug,首先我们必须知道这两个方法focusin(软键盘弹起事件)、focusout(软键盘关闭事件)。注意:这里的input框的位置是在页面的底部 废话不多说...
阅读 1602·2021-09-30 09:47
阅读 3606·2021-09-22 15:05
阅读 2841·2021-08-30 09:44
阅读 3625·2019-08-30 15:55
阅读 1376·2019-08-30 13:08
阅读 1330·2019-08-29 16:40
阅读 555·2019-08-29 12:45
阅读 1390·2019-08-29 11:25