uniapp: IOS微信小程序输入框部分被软键盘遮挡问题

一、问题描述

在IOS微信小程序中输入框底部被软键盘遮挡:

二、解决方案

小程序输入框被软键盘遮挡一部分的问题可以通过以下几种方法解决‌:

‌1.使用cursorSpacing属性‌ :在input或textarea元素上添加cursorSpacing属性,并设置一个合适的值(如20),这样可以留出光标到软键盘的距离,避免输入框被遮挡‌。

‌2.动态调整输入框位置‌

‌(1)获取键盘高度‌:给输入框添加keyboardheightchange事件,通过事件获取键盘的高度。例如:

复制代码
keyboardheightchange(event) {
  let height = event.detail.height || 0;
  this.keyBoardHeight = height 
}

(2)调整输入框位置‌:根据获取到的键盘高度动态调整输入框的位置。例如,将发送消息的盒子设置为固定位置,并动态调整其bottom值:

复制代码
<div class="send-msg" :style="{bottom: keyBoardHeight +'px'}">
  <textarea @keyboardheightchange="keyboardheightchange"></textarea>
</div >

注意:

(1)使用fixed属性‌:在弹窗定位中时需要加入fixed属性,否则在软键盘弹出时输入框可能不会显示在软键盘上面‌。

‌(2)处理安全区域‌:在iPhone X等有底部安全区域的设备上,可能需要特别处理安全区域。例如,在u-popup组件中设置safeAreaInsetBottom为false,以确保输入框在软键盘弹出时不会被遮挡‌。

相关推荐
天蓝色的鱼鱼27 分钟前
从“死了么”到“我在”:用uniCloud开发一款温暖人心的App
前端·uni-app
小徐_233331 分钟前
uni-app 组件库 Wot UI 的 AI 友好型编程指南
前端·uni-app
CHB17 小时前
uni-app x 蒸汽模式 性能测试基准报告 Benchmark
uni-app·harmonyos
whinc17 小时前
🚀 两年小程序开发,我把踩过的坑做成了开源 Skills
前端·微信小程序·ai编程
Lupino20 小时前
烧掉 10 刀 API 费,我才明白小程序虚拟列表根本不用“库”!
react.js·微信小程序
anyup21 小时前
月销 8000+,uView Pro 让 uni-app 跨端开发提速 10 倍
前端·uni-app·开源
小溪彼岸2 天前
是时候给想做小程序的小伙伴泼盆冷水了
微信小程序
远山枫谷3 天前
一文理清页面/组件通信与 Store 全局状态管理
前端·微信小程序
木易士心4 天前
一文读懂:微信小程序云数据库直连原理与使用指南
微信小程序·serverless
willow4 天前
uniapp实战
uni-app