安卓和ios 软键盘弹起和收起

1 目前来说,js 应该是没有直接获取手机键盘状态的api,但是可以通过一些其他的特点来判断当前的键盘弹起和收起

2 安卓键盘弹起会触发页面的resize 事件(苹果不会),所以可以通过判断页面高度的前后变化来判断键盘的状态。

3 ios 在键盘收起的时候input 会失去焦点(安卓不会),所以可以通过input 的focus 和 blur 事件来判断键盘的状态

  或者通过页面的foucein 和 focusout 来判断键盘的状态(有时候键盘收起并不会触发focusout 事件,需要滚动一点点之后才会)

4 ios 键盘在弹起的时候会让整个页面向上移动,键盘在页面的下面

5 安卓会改变窗口的高度,让整个窗口的高度变短,正常情况下,窗口的高度变短了之后里面内容的高度并不会变化,只是会隐藏掉,所以这个时候多出来内容就会看不到了。输入框就像是被键盘盖住了一样。

   解决:

   使用 在键盘弹起的时候使用document.activeElement.scrollIntoView(false)

滚动页面,让页面滚动到可视区域。

里面的false 是正好滚动到键盘上面,true 是滚动到最底部。

      

 if (window.phoneType == "android") {
            //获取原窗口的高度
            var originalHeight = document.documentElement.clientHeight || document.body.clientHeight;
            window.onresize = function() {
              //键盘弹起与隐藏都会引起窗口的高度发生变化
              var resizeHeight = document.documentElement.clientHeight || document.body.clientHeight;
              if (resizeHeight - 0 < originalHeight - 0) {
                //当软键盘弹起,在此处操作
                that.showBottomBar = false; 
                document.activeElement.scrollIntoView(false);//焦点元素滚到可视区域的问题
              } else {
                //当软键盘收起,在此处操作
                that.showBottomBar = true;
                document.body.scrollIntoView();       
                // window.scroll(0, 0);     
              }
            }
          }else if (window.phoneType == "ios") {
            document.body.addEventListener('focusin', () => {
              //软键盘弹出的事件处理
              that.showBottomBar = false;
            })

            let formDom = document.getElementById("confirmForm");
            let textareaL = formDom.querySelectorAll("textarea");
            textareaL.forEach(item => {
              item.addEventListener('blur', () => {
                // that.$toast("触发blur事件")
                //软键盘弹出的事件处理
                that.showBottomBar = true;
                document.body.scrollIntoView();
                window.scroll(0, 0);
              })
            })

          }

 

安卓iOS的输入框兼容性问题主要涉及以下几个方面: 1. 键盘样式:安卓iOS键盘样式有所不同,包括键盘的外观和布局。在开发过程中,应该针对不同平台设计相应的布局和样式。 2. 输入事件:安卓iOS的输入事件处理方式也有差异。在安卓上,通常使用EditText控件来处理输入,而iOS上则使用UITextField控件。开发时需要注意事件的注册和处理方式。 3. 输入类型:安卓iOS的输入类型也有差异,例如数字、文本、密码等。在定义输入框时,需要根据实际需求设置相应的输入类型,以确保输入的准确性和用户体验。 4. 软键盘弹出:安卓iOS软键盘弹出时的行为也有所不同。在安卓上,软键盘通常会覆盖输入框,需要自行处理页面内容的滚动以保证输入框可见;而在iOS上,系统会自动调整页面布局以确保输入框可见。开发时需要注意对软键盘弹出事件的处理。 为了解决安卓iOS的兼容性问题,可以采取以下一些措施: 1. 使用响应式布局:使用相对布局或者约束布局等响应式布局方式,可以根据不同平台的需求自动调整布局。 2. 使用平台相关的输入控件:在安卓iOS上分别使用EditText和UITextField等平台相关的控件,可以更好地适配不同平台的样式和行为。 3. 使用平台相关的事件处理方式:根据不同平台的事件处理方式,编写对应的代码逻辑,以确保输入事件能够正确响应。 4. 使用平台相关的属性设置:根据不同平台的属性设置,比如输入类型、软键盘行为等,调整相应的属性值。 总之,了解安卓iOS之间的兼容性差异,并采取相应的措施进行适配,能够更好地处理输入框兼容性问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值