h5页面在安卓手机被软键盘弹起引起的bug

问题

自己写了个fixed定位的popup弹出层,在安卓手机上点击输入框后,软键盘弹起,导致底部按钮被挤上去引起的相关bug

解决思路

fixed定位的元素高度需要确切px值,不能%或者vh
在页面初始化时获取到body高度,写个监听方法,页面高度变化时,给body高度重新设置为初始化获取到的值。

代码

componentDidMount(): void {
   this.setState({windowHeight: window.innerHeight})
   window.addEventListener('resize', this.handleResize.bind(this));
 }

 componentWillUnmount(): void {
   window.removeEventListener('resize', this.handleResize.bind(this));

 }

 handleResize = e => {
   this.setState({windowHeight: this.state.windowHeight})
 }

将windowHeight值赋值给fixed定位的元素,内部需要设置高度的元素可以利用calc加减一定的值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值