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,以确保输入框在软键盘弹出时不会被遮挡‌。

相关推荐
游戏开发爱好者818 分钟前
Charles 抓不到包怎么办?从 HTTPS 代理排错到底层数据流补抓的完整解决方案
网络协议·http·ios·小程序·https·uni-app·iphone
北漂的老猿3 小时前
知识付费小程序 梦想贩卖机v2
小程序
我命由我123455 小时前
微信小程序 - 避免在 data 初始化中引用全局变量
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
骨子里的偏爱6 小时前
uniapp实现数据存储到本地文件,除非卸载app,否则数据一直存在
javascript·chrome·uni-app
白菜__8 小时前
去哪儿小程序逆向分析(酒店)
前端·javascript·爬虫·网络协议·小程序·node.js
我命由我123458 小时前
微信小程序 bind:tap 与 bindtap 的区别
开发语言·前端·javascript·微信小程序·小程序·前端框架·js
_Jyann_9 小时前
uniapp两种方式实现自定义tabbar
前端·javascript·uni-app
郑州光合科技余经理9 小时前
PHP技术栈:上门系统海外版开发与源码解析
java·开发语言·javascript·git·uni-app·php·uniapp
2501_9159214310 小时前
Fiddler抓包工具详解,HTTPHTTPS调试、代理配置与接口分析实战教程
服务器·ios·小程序·fiddler·uni-app·php·webview
undsky10 小时前
【RuoYi-SpringBoot3-UniApp】:一套代码,多端运行的移动端开发方案
前端·uni-app