在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、改变布局:
之前的整个页面布局如下:
外层设置fixed的原因是不让页面在浏览器中进行上下拖拽,
最后形成的结果是:页面上移,但是布局未产生影响;
解决
改变页面布局:
外层fixed取消,改用 display:flex布局,将内容分为3部分,中间内容flex-grow: 1; 好了
【给input设置fixed或者input的父元素设置fixed 导致此了原因】