结构如下
我们需要做的就是当聚焦评论框的时候, ios 需要让键盘顶起评论框。在 ios 系统中,当键盘弹起的时候,会挤压页面,评论框会自然在顶部,但是有个问题就是,下面的评论框会不贴底,露出下面的东西,所以在 ios12 之前的解决办法就是在评论框触发 focus 的时候让页面滚动到底部,代码如下:
如果输入框失去焦点,就让页面滚动到先前的位置。
代码如下
这种方案在 ios12 上会出现两个问题:
<ul>
<li>如果在页面底部吊起输入框,输入框会被键盘挡住</li>
<li>如果在页面中部,行为会变得很奇怪,即使我们用了上面的方法,输入框会不贴底,众所周知在输入的时候,fixed定位会生效,即使我们禁用了touchmove事件,还是能够滚动</li>
</ul>
所以针对这些问题,我先试了网上这种据说通用的解决方法:
scrollIntoView 这种方法,但是报错了,没有这个方法。
然后我自己分析了一下这个问题,出现各种情况的原因是因为弹出键盘时,页面能够滚动,于是就出现了各种问题,那干脆让页面无法滚动。 ios11 及之前使用了下面的布局
并且禁止了 touchmove 事件,这样能够让页面无法滚动,但是 ios12 并没有什么卵用。还是能够滚动,那咱们就让内容就一屏,多的被截掉。下面是输入框 focus 的代码:
然后就是输入框触发 blur 事件时的代码:
在这里需要重新设置 body 的高度,高度为之前获取的 scrollHeight ,因为我们需要重新滚动到先前的位置,建议不要设置 height 为 auto ,因为在一些场景下我们可能需要监听滚动事件,会出现其他的问题(稳战稳打才能打胜仗)。然后重新设置 body 的 overflow ,让页面能够滚动,最后滚动到先前的位置。如不嫌弃小编个大家推荐一个内推技术群:707641720,进群可以在群文件里面获取这篇面试题的全部答案,学习资料,iOS相关方面的电子书。群里纯技术交流!