解决uniapp在App环境下输入框被软键盘遮挡的问题

本文介绍了两种解决uniapp在App环境下输入框被软键盘遮挡的方法:一是利用@keyboardheightchange事件动态调整;二是通过修改pages.json中softinputMode属性,设置为adjustResize或adjustPan,防止输入框被遮挡。同时指出了不同模式的优缺点。

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

方法一:通过@keyboardheightchange事件获取软键盘高度,进行调整

以下为官方对keyboardheightchange事件的解释。

@keyboardheightchange eventhandle 键盘高度发生变化的时候触发此事件,event.detail = {height: height, duration: duration} 微信小程序基础库2.7.0+、App 3.1.0+

在代码中添加如下处理

<view class="footer" :style="{bottom: changeBottomVal}">
    <input @keyboardheightchange="keyboardheightchange"/>
</view>

keyboardheightchange 方法

keyboardheightchange(e){
	this.changeBottomVal = e.detail.height + 'px'
}

css样式

.footer {
	position: fixed;
	bottom: 0;
	left: 0;
}

方法二:修改软键盘弹出模式,使用webview的高度变化,实现调整。

 在页面的pages.json中的style中做以下修改

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值