IOS评论框不贴底(ios12新bug)

栏目: Html · 发布时间: 5年前

内容简介:结构如下我们需要做的就是当聚焦评论框的时候,

结构如下

IOS评论框不贴底(ios12新bug)

我们需要做的就是当聚焦评论框的时候, 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 ,因为我们需要重新滚动到先前的位置,建议不要设置 heightauto ,因为在一些场景下我们可能需要监听滚动事件,会出现其他的问题(稳战稳打才能打胜仗)。然后重新设置 bodyoverflow ,让页面能够滚动,最后滚动到先前的位置。


以上所述就是小编给大家介绍的《IOS评论框不贴底(ios12新bug)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

奥美的数字营销观点

奥美的数字营销观点

[美] 肯特·沃泰姆、[美] 伊恩·芬威克 / 台湾奥美互动营销公司 / 中信出版社 / 2009-6 / 45.00元

目前,媒体的数字化给营销人带来了重大影响。新媒体世界具有多重特性,它赋予企业大量机会,同时也带来挑战。营销人有了数量空前的方式来与消费者互动。然而,许多人面对变革的速度感到压力巨大,而且不知道该如何完全发挥这些新选择所带来的优势。 本书为读者提供了如何运用主要数字媒体渠道的方法;随附了领先的营销人如何在工作中有效运用这些渠道的最佳案例;提供了数字营销的十二个基本原则;协助数字营销人了解什么是......一起来看看 《奥美的数字营销观点》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具