解决 android 软键盘弹出打乱布局的问题(js解决)

混江龙づ霸主 提交于 2020-01-22 02:14:16

问题基本描述

H5这个页面,内含一个输入框和一个 button,整个页面是全屏的(已经使用定位布局做了全面屏的适配),高度是 100vh。
在这里插入图片描述
当点击输入框时,手机软键盘会弹出,iphone 浏览器布局还是原来正常的,但是在 android ,则出现这样子:
在这里插入图片描述
可以看到,键盘弹起,页面的可视区域高度被压缩了,使整个页面布局发生了变化。

  • 刚开始我的基本样式:
/* 外层容器 */
.keyword-container{
  background: linear-gradient(#ea537e, #e82e3b);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
 }

分析解决

既然是容器高度被压缩,所以就要给容器固定的高度,但是要考虑不同的机型屏幕高度并不一样,所以需要使用 js 动态去获取屏幕高度,然后给到容器,思路就是这样。

mounted () {
    this.containerHeight = window.innerHeight  // 获取浏览器可用区域高度
},

绑定给最外层容器

<div class="keyword-container" :style="{ height: containerHeight + 'px'}">

CSS 需要有点改动

/* 外层容器 */
.keyword-container{
  background: linear-gradient(#ea537e, #e82e3b);
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
 }

去掉 top 是因为要保证软键盘弹起时,页面下部分位于软键盘上(像被软键盘顶起),这样输入框就会在可视区域内^_^

  • 解决后效果:
    在这里插入图片描述
如果这篇文章对你有帮助的话,请给个赞吧,谢谢 _~
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!