内容简介:结构如下我们需要做的就是当聚焦评论框的时候,
结构如下
我们需要做的就是当聚焦评论框的时候, 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
上会出现两个问题:
<ul>
<li>如果在页面底部吊起输入框,输入框会被键盘挡住</li>
<li>如果在页面中部,行为会变得很奇怪,即使我们用了上面的方法,输入框会不贴底,众所周知在输入的时候,fixed定位会生效,即使我们禁用了touchmove事件,还是能够滚动</li>
</ul>
所以针对这些问题,我先试了网上这种据说通用的解决方法:
scrollIntoView
这种方法,但是报错了,没有这个方法。
然后我自己分析了一下这个问题,出现各种情况的原因是因为弹出键盘时,页面能够滚动,于是就出现了各种问题,那干脆让页面无法滚动。 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
,让页面能够滚动,最后滚动到先前的位置。
以上所述就是小编给大家介绍的《IOS评论框不贴底(ios12新bug)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
DIV+CSS网站布局从入门到精通
2011-1 / 58.00元
《DIV+CSS网站布局从入门到精通》介绍了商业类型的网页设计,以及目前流行的div+CSS标准布局方法和实战技法。通过十个经典案例,分别从不同类型网站的布局风格以及实现方法来讲解div+CSS网页布局和制作方法。全书系统地讲解了CSS样式的基础理论和实际运用技术,并结合实例来讲解层叠样式表与层布局相结合制作网页的方法。在实例制作过程中除了介绍CSS样式设计各方面的知识外,还结合实际网页制作中可能......一起来看看 《DIV+CSS网站布局从入门到精通》 这本书的介绍吧!