博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
完美修复ios原生键盘遮挡input框
阅读量:30375 次
发布时间:2020-01-04

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

最近在做一个仿微信的聊天界面,有一个固定在页面底部的input框,本来使用fixed定位在底部,在android手机上没有任何问题,但在iOS上当点击输入内容的时候会出现不同情况的原生键盘遮挡输入框的情况。度娘出了很多解决方法,但没有一个方法可以完美解决,而且发现很多人都有这个问题,自己就苦思冥想出了一个相对不错的解决方法,跟大家分享一下。

先跟大家列举一下网上的解决方法,还有我的实践结果

position

// 修改position:fixed; position:absolute;// position:fixed;position:absolute;

实践证明没有任何影响,就算不使用定位也会出现遮挡输入框的情况

scrollTop

setTimeout(function(){    document.body.scrollTop = document.body.scrollHeight;},300)

这种方法在iOS10上可以解决遮挡的问题,但在iOS11上会出现键盘先将输入框顶上去然后输入框又快速回到屏幕底部再次被遮挡的情况

scrollIntoView scrollIntoViewIfNeeded

这两种方法完全看不出任何效果

我的解决方法

直接上代码

// css.mainBox{    height:100vh;    position:relative;}.inputBox{    position:absolute;    bottom:0;}// 输入框获得焦点事件onFocus() {    setTimeout(function(){        // 设置body的高度为可视高度+302        // 302为原生键盘的高度        document.getElementsByTagName('body')[0].style.height = (window.innerHeight + 302) + 'px';        document.body.scrollTop = 302;    }, 300)}// 输入框失去焦点事件onBlur() {    // 设置body恢复原来的高度    document.getElementsByTagName('body')[0].style.height = window.innerHeight + 'px';}
这种方法相当于给body增加一个键盘的高度,正好可以占掉键盘的位置,把页面内容顶上去,然后还要阻止一个body的滚动事件,防止用户滑动页面把增加的302的白页面滚动出来。(因为手边没有iPhone X手机,所以在iPhone X上兼容可能是不太完美,不过也就只是键盘的高度不同。可以通过判断手机型号设置不同高度的方式解决)
你可能感兴趣的文章
[LeetCode] 67. 二进制求和(简单模拟二进制求和)
查看>>
HDU1233(基础最小生成树 prim和 kruskal)
查看>>
终于找到可以一文多发的平台了!
查看>>
IntelliJ IDEA 2019 快捷键终极大全,速度收藏!
查看>>
第3章-5 字符转换 (15分)【python】
查看>>
L1-068 调和平均 (10 分)
查看>>
L1-069 胎压监测 (15 分)
查看>>
L1-071 前世档案 (20 分)
查看>>
L1-072 刮刮彩票 (20 分)
查看>>
L2-012 关于堆的判断 (25 分)
查看>>
L1-064 估值一亿的AI核心代码 (20 分)
查看>>
L2-033 简单计算器 (25 分)
查看>>
L2-034 口罩发放 (25 分)
查看>>
L2-019 悄悄关注 (25 分)
查看>>
L1-020 帅到没朋友 (20 分)
查看>>
L1-046 整除光棍 (20 分)
查看>>
L2-021 点赞狂魔 (25 分)【优化后的】
查看>>
L2-032 彩虹瓶 (25 分)
查看>>
L2-004 这是二叉搜索树吗? (25 分)
查看>>
[Error] ‘nullptr‘ was not declared in this scope解决方案
查看>>