手机端自动隐藏输入法。

作者: wengjq | 来源:发表于2016-12-14 17:35 被阅读292次

    最近接到产品的需求是要给移动手机端的所有的input和textarea框加上自动隐藏输入法的功能。即当用户调出输入法的时候,拖动滚动条自动隐藏输入法。

    于是,想到把事件写在滚动条上以及可以通过blur()事件去掉输入法,就有了下面的代码。

    Mobi.bindBodyScrollTypeWritingEvent = function(){
        var time = 60, // 60毫秒的间隔 
        timer;
        window.onscroll = null;
        window.onscroll = function(){
          //函数节流
          if(typeof timer != "number"){
              timer = setTimeout(function(){
                  var elem = document.activeElement;//焦点元素
                  if(document.activeElement.tagName == "INPUT" || document.activeElement.tagName == "TEXTAREA"){
                      elem.blur(); 
                  }
                  timer = null;
              }, time);
          }
        }
    }
    

    本来以为这样就ok了,后面经测试发现当用户的网页里的input或者textarea框在屏幕的下方(即在屏幕的一半以下)时,此时用户点击输入框,手机浏览器会自动把在屏幕下方的输入框移到上方(即比较舒服的位置),进而间接导致了拖动了滚动条,结果触发了上面代码的scroll事件,所以此方案不行。。。


    此时产品加了个小优化,及当点击非输入框时,自动隐藏输入法。


    换了个思路,觉得应该从手指的touch事件去解决问题。网上查了下资料,没有特别好的解决方案。于是决定用touchend,因为每次触摸完屏幕才隐藏输入法,测试了下用touchend事件在安卓手机上测试时ok的,但在苹果手机上拖动滚动条时是不触发这个touchend事件的。最后,把touchend事件改为touchstart事件,问题解决。代码如下:

    Mobi.bindBodyScrollTypeWritingEvent = function(){
        function mobiEnteringBlur(elem,time){
            var time = time || 100;
            if(elem.length == 0){
                return;
            }
            var docTouchStart = function(event){
                //点击非本节点及点击的节点不是输入框才blur()
                if(event.target != elem && event.target.tagName != 'INPUT' && event.target.tagName != 'TEXTAREA'){
                    setTimeout(function(){
                        elem.blur();
                        document.removeEventListener('touchstart', docTouchStart, false);
                    },time);
                }
            };
            elem.addEventListener('focus', function(){
                document.addEventListener('touchstart', docTouchStart, false);
            },false);
        }
        var elems = document.querySelectorAll('input,textarea');
        for(var i = 0;i < elems.length;i++){
            var inputField = new mobiEnteringBlur(elems[i]);
            inputField = null;
        }
    }

    相关文章

      网友评论

        本文标题:手机端自动隐藏输入法。

        本文链接:https://www.haomeiwen.com/subject/funimttx.html