手机端自动隐藏输入法。

作者: 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;
    }
}

相关文章

  • 手机端自动隐藏输入法。

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

  • Windows语音输入

    中文语音输入法推荐讯飞语音输入法,讯飞在ios等手机端已经很普及了,锤子手机也把它作为一个重要的卖点。在电脑端讯飞...

  • Android疑难杂症之Dialog消失,关闭输入法

    由于项目需要,实现一个小需求: 1) 有一个功能是弹出一个输入框,自动弹出输入法2)关闭时 ,自动隐藏输入法 感觉...

  • 这款良心输入法,时隔五年再次更新!

    说到输入法,无论是PC端还是移动端,搜狗输入法都是市场占有率极高的一款输入法,作为老牌输入法,虽然广告、弹窗很多,...

  • 使用PC远程调试移动端Web页面

    目的 只有手机端才能更方便的调试一些特有操作: 如多点触控/弹出输入法, 但手机端又不能很好的使用F12控制台. ...

  • ios 11 滑动时会隐藏tab

    今天遇到了一个非常奇葩的问题,一些移动端页面在ios的某些手机上,当页面滑动的时候会自动隐藏底部tab,经过多方排...

  • 双拼输入法不适合我

    结论 双拼适合在手机上和非工作场合的电脑上使用。 电脑输入法 搜狗输入法 Mac自带输入法 手机输入法 QQ输入法...

  • 为什么讯飞语音输入法是我的最爱

    认可讯飞输入法是在手机端开始的,每天要在有道云笔记写日记,讯飞输入法的连重叠写功能让我有书写的快感,输入的速度也大...

  • 2021-01-26

    或许在许多人的认知里,输入法还属于纯粹的“C端”产品。 市场调研机构艾媒咨询却在《2020中国第三方手机输入法场景...

  • 提高3倍输入效率的两款输入法

    你需要提高移动端和PC端输入效率。 随着电脑、手机等电子设备的普及,我们每天都会频繁的用到输入法,而一款高效的输入...

网友评论

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

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