【微信小程序】底部弹窗固定定位fixed+textarea,导致的adjust-position在安卓手机失效问题

安卓手机测试时候发现,fixed固定定位导致键盘弹出时,textarea无法正常被顶上去。

然后我就尝试了第二种方法用scroll-view将高度设置为100vh时,将页面保持在视口高度,这个时候发现不管是弹窗是fixed还是absolute都无法让安卓手机的键盘弹出时textarea顶上去

最后我用了最后一种办法,有需要可以看一下

对于底部弹出的组件我把它高度设置为正常高度+键盘高度,至于键盘高度则去监听键盘的弹出从而获取键盘高度,至于键盘高度变化这部分的动画效果用transition:all 100ms;

javascript 复制代码
//popup是我自己写的底部弹出组件,可以自己写一个
//keyboardHeight为键盘高度
<popup bindblanktap='tapMask' popHeight="{{426+keyboardHeight}}rpx" wx:if='{{showFloatInput}}' id='popup'>
     <view class="textarea">
     //adjust-position键盘弹起时,是否自动上推页面,将他设置为false
      <textarea show-confirm-bar='{{false}}' style="height: 160rpx;" focus="{{textarea_focus}}" class="" adjust-position="{{false}}" value="{{inputvalue}}" placeholder="{{placeholder}}" placeholder-style="color:#bbb; padding-top:10rpx" bindinput="onTextareaInput" bindkeyboardheightchange="bindkeyboardheightchange"></textarea>
    </view>
</popup>



//监听键盘
bindkeyboardheightchange: function (e) {
      var that = this;
      let keyboardHeight = e.detail.height;
      that.setData({
        keyboardHeight: (keyboardHeight * 750 / wx.getSystemInfoSync().windowWidth) 
      });
},
相关推荐
艾iYYY5 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
xyzzklk6 小时前
解决Salesforce无法向外发送邮件
android·java·开发语言·网络·crm·salesforce·客户关系管理
修炼者8 小时前
Gradle三阶段
android
morchalen8 小时前
安卓framework学习6:Contacts 联系人 APP 日志
android
KANGBboy9 小时前
java知识四(面向对象编程)
android·java·开发语言
涓涓52712 小时前
适合中小微企业的进销存工具,通常更看重手机电脑同步与权限管控
智能手机·进销存软件
AD钙奶-lalala12 小时前
Android Studio新建项目默认不使用Compose模版
android·ide·android studio
故渊at14 小时前
第一板块:Android 系统基石与运行原理 | 第二篇:Android 编译、打包与安装机制
android·系统架构·apk·打包·application·dalvik·android编译
地球@+jdhb4414 小时前
2026最新小红书无水印保存教程:手机电脑全场景实测,原图画质直接拿
智能手机·notepad++
故渊at14 小时前
第一板块:Android 系统基石与运行原理 | 第三篇:ART 与 Dalvik 运行时环境原理
android·对象模型·内存布局·运行原理·art·dalvik