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

本文介绍了一种解决安卓设备上软键盘弹出导致H5页面布局变化的方法。通过使用JavaScript动态获取屏幕高度,并将其应用于页面容器,确保了键盘弹出时输入框仍处于可视区域内。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题基本描述

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 是因为要保证软键盘弹起时,页面下部分位于软键盘上(像被软键盘顶起),这样输入框就会在可视区域内^_^

  • 解决后效果:
    在这里插入图片描述
如果这篇文章对你有帮助的话,请给个赞吧,谢谢 _~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值