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

1:Android、ios 同时解决;

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

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

上代码
<!-- 你的其他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>

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

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在使用uniapp开发ios应用时,当我们在textarea输入内容时,有时会出现被输入法键盘挡住的情况。这个问题是由于ios对于输入框的默认处理机制所引起的。 为了解决这个问题,我们可以采取以下几种方案来避免textarea被挡住的情况。 1. 使用scroll-view来承载textarea组件,通过设置scroll-view的属性使其能够嵌套textarea,并且在键盘弹出时自动滚动,保证textarea永远在可视区域内。具体代码如下: ```html <scroll-view scroll-y :scroll-with-animation="true" :style="'height: ' + scrollHeight + 'px'" @scroll="onScroll"> <textarea v-model="content" :style="'height: ' + textareaHeight + 'px;'" @focus="onFocus"></textarea> </scroll-view> ``` ```javascript data() { return { scrollHeight: 0, textareaHeight: 0 } }, methods: { onScroll(event) { this.scrollHeight = event.detail.scrollHeight; }, onFocus() { this.textareaHeight = '300'; // 设置一个合适的高度 } } ``` 2. 使用native组件来替代textarea组件,在ios平台上使用原生的输入框来实现输入功能。这样可以避免ios的输入框默认处理机制,从而不会出现被挡住的情况。具体代码如下: ```html <native-input type="text" @input="onInput"></native-input> ``` ```javascript onInput(event) { this.content = event.detail.value; } ``` 3. 修改iOS的输入框样式和位置,使其不会挡住textarea。我们可以通过设置css样式来实现。具体代码如下: ```html <textarea style="position: fixed; bottom: 0; width: 100%;" v-model="content" @focus="onFocus"></textarea> ``` ```javascript onFocus() { document.documentElement.scrollTop = document.documentElement.scrollHeight; } ``` 以上是三种解决uniapp在iOS平台上textarea被挡住的方法,根据具体项目需求选择合适的方案来解决这个问题
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值