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

3 篇文章 0 订阅
1 篇文章 0 订阅

在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 导致此了原因】

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值