在做移动端的时候,很多底部固定的导航栏,目的是想让导航栏一直固定到底部,不随输入键盘的出现而移动。在苹果手机上没事,但在安卓手机上弹出的键盘会将按钮顶起来。事实是这样的:一个页面有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;
             		}
             	}
             };