美文网首页
移动端中 H5输入框在弹起键盘后被遮挡

移动端中 H5输入框在弹起键盘后被遮挡

作者: 景阳冈大虫在此 | 来源:发表于2018-08-06 18:04 被阅读0次
页面在app中与不在的对比

可见,键盘遮盖住了这个输入框,而且此时不能滚动,而按钮的设计为始终置底
置底的按钮为fixed布局,观察得知,这样当键盘弹起时,其实页面的高度被缩短成类似于这样


app中

这样,始终置底的元素会遮盖住输入框,并且由于界面并没有长到可以滚动的地步,输入框非常正常地被遮住了
【解决办法】

第一种(兼容性优先):

首先,把置底元素设置成,在页面的底部而非屏幕的底部

.page .bottom {
    position: absolute;
    bottom: 0;
    width: 100%;
    border: 0;
    text-align: center;
    z-index: 5;
}

然后,设置页面的高度,让按钮有置底的效果

.page {
    background: #fff;
    color: #384369;
    position: relative;
    width: 100%;
    overflow-y: auto;
    height: 100vh;
    min-height: 480px;
}

注意有最小高度,因为当键盘弹起时,100vh是缩小的那部分的高度,而不是屏幕高度
*如果有大屏的需求,适配一下就好

这样,当键盘弹起时,内容就是可以滚动的了,出于用户体验的需求,可以在focus输入框的时候,把滚动条划一下,露出输入框

function whenFocus(){
        document.body.scrollTop = document.documentElement.scrollTop =86;
}

具体的数值可以再调整

第二种(兼容性优先):
<div class="main">
    <div class="content"></div>
    <button></button>
</div>

设置content为 overflow: auto;
让content的高度为 100vh-buttonHeight

第三种(flex布局):

使用第二种的html

.main{
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
   .content {
        overflow: auto;
    }
}

其实....上面的方法都不咋好使

终极解决方法

利用window.resize方法,这个方法的特性是:当调整浏览器窗口的大小时,发生 resize 事件。

data(){
    return{
        screenHeightNoChange: true,
    }
},
mounted() {
    const self = this;
    window.onresize = () => {
        if (self.oldFullHeight) {
            self.screenHeightNoChange = document.documentElement.clientHeight === self.oldFullHeight;
            console.log(' self.screenHeightNoChange ' + self.screenHeightNoChange);
        }
    };
},

screenHeightNoChange==true的时候使用方法三,当==false的时候,将button变成position:relative; 就能解决问题了
以上,就是解决问题的方法了

相关文章

网友评论

      本文标题:移动端中 H5输入框在弹起键盘后被遮挡

      本文链接:https://www.haomeiwen.com/subject/agmgvftx.html