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:真的是各种坑等着你跳,大家有好的方法也可以提供过来;谢谢参考!