移动端页面 手机键盘挡住了输入框

正常情况
图片描述

问题
图片描述

每次当手机切换app或窗口时,再回到该页面时 第一次 点击输入框,键盘就会把输入框挡住,只有第一次点击会挡住。
这是什么原因导致的?
然后我发现此时页面的滚动条是没有滚动到最底部, 所以我给输入框聚焦时绑定了个事件
$('.input').on('focus', function() {

$(window).scrollTop(99999);

});
但是页面的滚动条还是没有滚到最底部,输入框还是给键盘挡住了。

$(document) 
$('body, html') 也试过了.
     
阅读 10.4k
6 个回答

解决方案
在input 获得焦点 或者 单击事件里面添加
setTimeout(function () {

document.body.scrollTop = document.body.scrollHeight;

}, 500);

使用该方法解决了, 之前也试过让滚动条滚动到底部, 但是无效, 现在加了个定时器之后可以了, 定时器时间自己调整, 我设置了500ms才不会出现遮挡问题.

安卓浏览器在软键盘弹出后不会像iOS浏览器那样重新计算window的高度,所以导致安卓浏览器window的高度在软键盘弹出的时候为“软键盘的高度+(window的高度-软键盘的高度)”;而其实,此时,合理的高度应该是页面的高度+软键盘弹出的高度;就此解决方案为如下:

var winHeight = $(window).height(); //获取当前页面高度  
          $(window).resize(function() {  
              var thisHeight = $(this).height();  
              if (winHeight - thisHeight > 50) {  
                  //当软键盘弹出,在这里面操作  
                  //alert('aaa');  
                  $('body').css('height', winHeight + 'px');  
              } else {  
                  //alert('bbb');  
                  //当软键盘收起,在此处操作  
                  $('body').css('height', '100%');  
              }  
          });  

是不是fixed的问题?如果底部输入框使用了fixed的话 建议去掉 用flex布局使得输入框置于底部

推荐问题
宣传栏