码迷,mamicode.com
首页 > 微信 > 详细

IOS微信点击input弹出输入法,关闭后页面留白解决方案

时间:2019-03-19 21:43:39      阅读:262      评论:0      收藏:0      [点我收藏+]

标签:场景   class   view   判断   ipa   解决方案   src   app   ret   

 

  场景:IOS用微信点击input框弹出输入法后

     技术图片

 

    不管你是输入信息,还是不输入直接点完成关闭输入法,都会导致页面被挤上去后产生留白,从而改变页面布局

    技术图片           技术图片

 

 

 

    

  解决方法:

      给input添加blur(失去焦点)事件,让页面强制回滚,距离为0,代码如下  

$("input").blur(function(){
    document.body.scrollTop = document.documentElement.scrollTop = 0;
});

        原文出处:https://blog.csdn.net/KenThomas/article/details/86691404

 

  

  补充:

    最开始找到的方法并不是上面那个,而是下面这个看似比较复杂的代码,虽然也能够解决问题

var u = navigator.userAgent, app = navigator.appVersion;
    var isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端
    $(document).ready(function(){
        $("input").blur(function(){
            if (isIOS) {
                blurAdjust()
                // alert("1231321233")
            }
        });
    });
// 解决苹果不回弹页面 function blurAdjust(e){ setTimeout(()=>{ // alert("1231321233") if(document.activeElement.tagName == ‘INPUT‘ || document.activeElement.tagName == ‘TEXTAREA‘){ return } let result = ‘pc‘; if(/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) { //判断iPhone|iPad|iPod|iOS result = ‘ios‘ }else if(/(Android)/i.test(navigator.userAgent)) {  //判断Android result = ‘android‘ } if( result = ‘ios‘ ){ document.activeElement.scrollIntoViewIfNeeded(true); } },100) }

       原文出处:https://blog.csdn.net/m0_37520980/article/details/86305488

 

  注:虽然上面2种方法都能解决问题,但从代码的冗杂度来看,显然第一种更好,代码量更少,也更容易理解。

    所以小伙伴们在查找问题解决方法时,建议抱着还有更简单的方法的心理多试着找一找

     

 

    

 

IOS微信点击input弹出输入法,关闭后页面留白解决方案

标签:场景   class   view   判断   ipa   解决方案   src   app   ret   

原文地址:https://www.cnblogs.com/tu-0718/p/10561360.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!