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

一 . 需求描述 :

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

二 . 错误处理方案:

**方案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>
相关推荐
一字白首18 小时前
小程序组件化进阶:从复用到通信的完整指南DAY04
前端·小程序·apache
读忆18 小时前
你是否用过Tailwind CSS?你是在什么情况下使用的呢?
前端·css·经验分享·笔记·taiiwindcss
阿珊和她的猫18 小时前
探秘小程序:为何拿不到 DOM 相关 API
前端·小程序
FlyWIHTSKY18 小时前
Vue 3 onMounted 中控制同步与异步执行策略
前端·javascript·vue.js
蜗牛攻城狮18 小时前
【Vue3实战】El-Table实现“超过3行省略,悬停显示全文”的完美方案(附性能优化)
前端·vue.js·性能优化·element-plus
孙12~18 小时前
前端vue3+vite,后端SpringBoot+MySQL
前端·html·学习方法
隔壁小邓18 小时前
vue的组件化的理解之单独拆分的组件&组件的封装
前端·javascript·vue.js
困惑阿三19 小时前
全栈部署排雷手册:从 405 报错到飞书推送成功
服务器·前端·后端·nginx·阿里云·node.js·飞书
无名-CODING19 小时前
从零开始!Vue3+SpringBoot前后端分离项目Docker部署实战(下):Vue前端Nginx反代与致命坑点盘点
前端·spring boot·docker
我命由我1234519 小时前
Element Plus 问题:选择框表单校验没有触发
开发语言·前端·javascript·html·ecmascript·html5·js