解决安卓手机在input获取焦点时候固定定位元素被输入键盘给顶到顶部

在做移动端的时候,很多底部固定的导航栏,目的是想让导航栏一直固定到底部,不随输入键盘的出现而移动。在苹果手机上没事,但在安卓手机上弹出的键盘会将按钮顶起来。事实是这样的:一个页面有input的时候,然后聚焦input的时候,输入键盘就出现了,原本固定在底部的导航栏也不是在最底部固定着了,而是在键盘上部。最初的解决方法是以为用input聚焦的时候,就把固定导航栏隐藏掉,失去焦点的时候就把固定导航栏显示。可是事实又告诉我 ,失败了。有些手机可能行,但是有些手机,键盘可以隐藏,但是不可以失去焦点。所以就想到了另一个方法,也就是可行的方法:

键盘弹出,改变了窗口的大小;

//大概的HTML代码
<body>
<section class="section1">
    <form>
        <input type="text" placeholder="请输入医生、或者门店关键字" class="keyName" id="serachData">
    </form>
    <img src="./images/Search.png" alt="">
</section>

<section class="section3">
    <div class="more">
        <div class="moreBtn">更多</div>
        <div class="myApoint"><a href="我的预约.html">我的预约</a></div>
    </div>
    <div class="loadMore">加载更多</div>
</section>
</body>

 

//jQuery代码
//让固定定位始终定在手机的同一个位置
//先定义一个变量,当改变窗口大小的时候用来做判断
           var flagKey=false;
             $(".keyName").on("focus",function () {
               flagKey=true;
             })
             window.onresize =function(){
             	if(flagKey){
             		$(".more").css("position","initial");
             		flagKey=false;
             	}else{
             		$(".more").css("position","fixed");
             		if(document.activeElement.id =="serachData"){
             			flagKey = true;
             		}
             	}
             };

  

 

转载于:https://www.cnblogs.com/ouyangyulin/p/7850975.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值