微信小程序键盘弹起时,底部输入框抬起至键盘上方,顶部导航栏固定不动

一 . 需求描述 :

在微信小程序中,常见的页面布局是顶部导航栏和底部输入框固定不动,中间内容部分自适应。但是当键盘弹起时整个页面被挤压,导致元素上移或被覆盖,业务希望在这种情况下,输入框能自动抬起至键盘上方,顶部导航栏保持固定,不被顶上去。效果如图所示:

二 . 错误处理方案:

**方案1:**直接在textarea组件中设置cursor-spacing="100",这样当键盘弹时,输入框虽然在键盘上方,但是顶部导航栏也被顶上去了,效果如图一:

**方案2:**直接在textarea组件中设置adjust-position="{{false}}",这样当键盘弹起时,虽然顶部导航栏固定不动,但是底部输入框被键盘遮挡,效果如图二:

三 . 正确处理方案:

1.定义底部输入框外层view距离底部距离的变量inputBoxBottom:

css 复制代码
data:{
  inputBoxBottom:0
}

2.在页面的onLoad生命周期中监听键盘事件,记录键盘弹起的高度,并将高度赋值给inputBoxBottom

typescript 复制代码
 onLoad(options: any) {
    wx.onKeyboardHeightChange((res) => {
      const height = res.height;
      if (height > 0) {
        this.onKeyboardShow(height);
      } else {
        this.onKeyboardHide();
      }
    });
  },
onKeyboardShow(height: number) {
    this.setData({
      inputBoxBottom: height,
    });
},
onKeyboardHide() {
    // 处理键盘收起逻辑
    this.setData({
      inputBoxBottom: 0,
    });
}

3.将inputBoxBottom变量设置给底部输入框外层的view标签:

ini 复制代码
<view class="input-box" style="bottom:{{inputBoxBottom}}px"></view>

4.设置textarea标签adjust-position="{{false}}",保证键盘弹起时,页面不会被顶起,只是底部输入框bottom变化而使输入框抬起至键盘上方:

css 复制代码
<textarea adjust-position="{{false}}" ></textarea>
相关推荐
excel1 小时前
Vue3 中的双向链表依赖管理详解与示例
前端
前端小白从0开始1 小时前
Chrome DevTools高级用法:性能面板内存泄漏排查
前端·chrome·chrome devtools
EveryPossible1 小时前
带有渐变光晕
前端·javascript·css
jojo是只猫2 小时前
Vue 3 开发的 HLS 视频流播放组件+异常处理
前端·javascript·vue.js
卓码软件测评2 小时前
第三方软件登记测试机构:【软件登记测试机构HTML5测试技术】
前端·功能测试·测试工具·html·测试用例·html5
CS Beginner2 小时前
【html】canvas实现一个时钟
前端·html
林烈涛2 小时前
js判断变量是数组还是对象
开发语言·前端·javascript
Komorebi_99993 小时前
Unocss
开发语言·前端
goto_w4 小时前
前端实现复杂的Excel导出
前端·excel
Baklib梅梅4 小时前
2025文档管理软件推荐:效率、安全与协作全解析
前端·ruby on rails·前端框架·ruby