解决uniapp,textarea拉起页面被顶起和键盘被输入框遮挡的问题。

1:Android、ios 同时解决;

2:我们在开发的时候会发现textarea或者input拉起键盘的时候整个页面被顶起了,header也被顶没了;官方给了:adjustPosition='false'属性,设置完之后页面就不会被顶起,但是键盘把输入框挡住了,就很恶心;

3:我的实现思路是,adjustPosition='false' ;用@keyboardheightchange监听键盘的高度;在textarea下面给一个view标签并且加高度;再通过uni.pageScrollTo 在键盘拉起的时候上滑页面;

上代码
html 复制代码
<!-- 你的其他dom元素 写多少都可以 -->

<view>
     <textarea  border='none' :adjustPosition='false'   placeholder="请输入200字以内的申请人意见" count maxlength='500' @keyboardheightchange='keyboardheightchange' style="width: 100%;"   @blur="hideBorad"></textarea>
     <view :style="{'height':(showKeyNum==1?400:keyboardHeight)+'rpx'}"> </view>
</view>
javascript 复制代码
 export default{
	data() {
			return { 
				keyboardHeight: 0, // 键盘高度
				showKeyNum: 0,//键盘打开的次数
            }
        },
        methods: {
			keyboardheightchange(e) {
				this.keyboardHeight = e.detail.height;
				this.showKeyNum++;
				setTimeout(() => {
					uni.pageScrollTo({
						scrollTop: 2000
					});
				}, 200)
			},
		    hideBorad() {
			this.showKeyNum = 2;
			this.keyboardHeight = 0;
		   }
       }
 }

1:解释一下为什么要设置键盘打开的次数:是因为keyboardheightchange第一次拉起的时候键盘的高度监听不到,所以当等于1 的时候给了一个默认的高度;

2; @blur="hideBorad" 为什么要设置这个事件,是因为Android系统下keyboardheightchange关闭的时候不触发;

3:真的是各种坑等着你跳,大家有好的方法也可以提供过来;谢谢参考!

相关推荐
笨笨狗吞噬者7 小时前
uni-app 编译小程序原生组件时疑似丢属性,可以给官方提 PR 了
前端·微信小程序·uni-app
摇滚侠10 小时前
JAVA 项目教程《苍穹外卖-11》,微信小程序项目,前后端分离,从开发到部署
java·开发语言·微信小程序
雨雨雨雨雨别下啦14 小时前
【从0开始学前端】从0搭建uni-app小程序脚手架
小程序·uni-app
AnalogElectronic15 小时前
uniapp学习8,电动车充电小程序
学习·小程序·uni-app
2501_9159214315 小时前
iPhone 定位功能测试时不越狱来修改手机位置的方法
android·ios·智能手机·小程序·uni-app·iphone·webview
TE-茶叶蛋16 小时前
安卓应用(uniapp开发)分享微信-申请appid
android·微信·uni-app
AnalogElectronic17 小时前
uniapp学习9,同时兼容h5和微信小程序的百度地图组件
学习·微信小程序·uni-app
游戏开发爱好者817 小时前
iOS 开发进阶,用 SniffMaster 实现 iPhone 抓包深度分析
android·ios·小程序·https·uni-app·iphone·webview
AnalogElectronic1 天前
uniapp学习5,兼容微信小程序的俄罗斯方块游戏
学习·微信小程序·uni-app
克里斯蒂亚诺更新1 天前
微信小程序调用腾讯地图路线规划-注意点
微信小程序·小程序