ios 微信浏览器下 input失去焦点后 软键盘收起后 被撑起上移动的页面 没有归位

在iOS 微信浏览器下 input 获取焦点软键盘弹起把页面整体往上撑起了移动了一定距离,   失去焦点后 软键盘收起后 被撑起往上移动的页面没有归位,导致页面上的元素错位,点击按钮,input输入框等的位置发生错位。

解决办法两种:

1、当input失去焦点后,使用js将页面滚动到顶部。

//滚动到顶部
            scrollToTop:function(){
                setTimeout(function() {
                    // 获取原来的滚动距离
                     var scrollHeight = document.documentElement.scrollTop || document.body.scrollTop || 0;
                     window.scrollTo(0, Math.max(scrollHeight - 1, 0));

                   // window.scrollTo(0, 0);
                }, 100);
            },

2、改变布局:

之前的整个页面布局如下:

ios 微信浏览器下 input失去焦点后 软键盘收起后 被撑起上移动的页面 没有归位_第1张图片

外层设置fixed的原因是不让页面在浏览器中进行上下拖拽,

最后形成的结果是:页面上移,但是布局未产生影响;

解决

改变页面布局:

外层fixed取消,改用 display:flex布局,将内容分为3部分,中间内容flex-grow: 1; 好了

【给input设置fixed或者input的父元素设置fixed 导致此了原因】

你可能感兴趣的:(移动端,javaScript,html+css)