博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
IOS评论框不贴底(ios12新bug)
阅读量:6829 次
发布时间:2019-06-26

本文共 1413 字,大约阅读时间需要 4 分钟。

结构如下

我们需要做的就是当聚焦评论框的时候,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,让页面能够滚动,最后滚动到先前的位置。

转载地址:http://qsnkl.baihongyu.com/

你可能感兴趣的文章
搜狗输入法漏洞获取系统权限0day再述
查看>>
常见的WebPack文件、什么是WebPack
查看>>
DVD刻录机的使用与维护
查看>>
乌班图的世界——建立文件夹和空文件
查看>>
构建Postfix邮件系统(二) -- SMTP认证发信+SquirrelMail
查看>>
Oracle 使用concat函数需要注意的地方
查看>>
数据库默认排序
查看>>
Postgresql基于时间点恢复PITR案例(二)
查看>>
iOS 从app跳到设置界面
查看>>
条件测试
查看>>
Android SeekBar自定义使用图片和颜色显示
查看>>
从零开始部署bind9服务器之四: 配置192.168.1.102
查看>>
zookeeper学习之三(Curator客户端)
查看>>
selenium应用
查看>>
linux磁盘管理
查看>>
索骥馆-走向世界之《用美国小孩的方法学英文动词》扫描版[PDF]
查看>>
Android之基于XMPP协议即时通讯软件(三)
查看>>
对SEO网站优化使用技巧的总结
查看>>
yolov3 darknet:parser.c:315: failed
查看>>
网络MSDTC(分布式事务处理协调器)服务配置方法
查看>>