修复IM完整版接入小程序后,聊天页面键盘弹起时,页面高度错误问题

修复方案(请按以下步骤实现)

第一步:MessageInput 组件修复
  1. 禁用原生键盘顶推 :在 <input> 上设置 :adjust-position="false",改为手动控制布局
  2. 监听键盘高度变化 :在组件 mounted / onMounted 中调用 uni.onKeyboardHeightChange
  3. 手动控制 paddingBottom :用一个响应式变量 keyboardHeight 存储键盘高度,在最外层容器上绑定动态样式:
  4. 键盘弹出时收起面板 :在键盘高度 > 0 时,设置 showMorePanel = false
  5. 跨组件通知消息列表 :在键盘高度 > 0 时,通过 uni.$emit('键盘高度变化事件名', height) 通知 MessageList 组件
  6. 组件销毁时清理监听 :在 beforeDestroy(Vue2)/ onUnmounted(Vue3)中调用 uni.offKeyboardHeightChange()
第二步:MessageList 组件修复
  1. 监听键盘事件 :在 mounted / onMounted 中使用 uni.$on('键盘高度变化事件名', callback) 监听
  2. 自动滚动到底部:收到键盘弹出事件后,调用 scrollToBottom
  3. 修复重复滚动不触发问题:如果使用 scroll-into-view,需要先将目标 ID 清空为 '',等 50ms 后再重新赋值目标消息 ID,确保相同值时也能触发滚动
  4. 组件销毁时清理 :在 beforeDestroy / onUnmounted 中调用 uni.$off('键盘高度变化事件名') 配对注销
相关推荐
空中海7 小时前
第七章:vue工程化与构建工具
前端·javascript·vue.js
2501_9160088910 小时前
深入解析iOS应用启动性能优化策略与实践
android·ios·性能优化·小程序·uni-app·cocoa·iphone
旷世奇才李先生10 小时前
Vue3\+Vite\+Pinia实战:企业级后台管理系统完整实现(附源码)
vue.js
Cdlblbq14 小时前
搜索会员中心 创作中心Vue2项目一键打包成桌面应用
前端·javascript·vue.js·electron
A_nanda16 小时前
vue实现后端传输逐帧图像数据
前端·javascript·vue.js
当时只道寻常16 小时前
Vue3 集成 NProgress 进度条:从入门到精通
前端·vue.js
米丘16 小时前
Vue 3.x 单文件组件(SFC)模板编译过程解析
前端·vue.js·编译原理
米丘17 小时前
vue3.x 内置指令有哪些?
前端·vue.js
米丘17 小时前
Vue 3.x 模板编译优化:静态提升、预字符串化与 Block Tree
前端·vue.js·编译原理
TuCoder17 小时前
制作景区导览小程序时,现有手绘图是否可以复用?
小程序·智慧景区·手绘地图·景区导览·电子导览·地图制作·ebmap