fixed布局在移动端出现的问题及解决方案

今天给大家分享一下fixed布局在移动端出现的问题及解决方案。

1.背景介绍

  移动端业务开发,iOS 下经常会有 fixed 元素和输入框(input 元素)同时存在的情况。但是 fixed 元素在有软键盘唤起的情况下,会出现许多莫名其妙的问题。

2.知识剖析

  IOS下的fixed+input出现的bug现象,     一个简单的demo:

 

  < main>      

 < input type="text" placeholder="Footer..."/>   

     < button class="submit">提交< /button>        

    < /main>                 

   < footer>                 

  < /footer>

我们给上面的html加一个样式,如下

header, footer, main {

display: block;

}

footer {

position: fixed;

height: 34px;

left: 0;

right: 0;

bottom: 0;

}

main {

margin-bottom: 34px;

height: 2000px;

}

显示如下:

fixed布局在移动端出现的问题及解决方案_第1张图片

显示正常,但是我们一旦点击输入框,底部软键盘被唤起后,就会出现这种现象

fixed布局在移动端出现的问题及解决方案_第2张图片

                              我们可以看到,fixed的footer跑到屏幕中间去了

                   在某些安卓里面(如锤子SM705,安卓4.4.2)看这样:

fixed布局在移动端出现的问题及解决方案_第3张图片

fixed 定位好的元素跟随页面滚动了起来… fixed 属性失效了!这是为什么呢?

简单解释下: > 软键盘唤起后,页面的 fixed 元素将失效(即无法浮动,也可以理解为变成了 absolute 定位),所以当页面超过一屏且滚动时,失效的 fixed 元素就会跟随滚动了。

这便是 iOS 上 fixed 元素和输入框的 bug 。其中不仅限于 type=text 的输入框,凡是软键盘(比如时间日期选择、select 选择等等)被唤起,都会遇到同样地问题。

4.解决方案

既然在 iOS 下由于软键盘唤出后,页面 fixed 元素会失效,导致跟随页面一起滚动,

那么假如——页面不会过长出现滚动,那么即便 fixed 元素失效,也无法跟随页面滚动,也就不会出现上面的问题了。

那么按照这个思路,如果使 fixed 元素的父级不出现滚动,而将原 body 滚动的区域域移到 main 内部,而 header 和 footer 的样式不变,代码如下:

html代码

提交

css样式

header, footer, main {

display: block;

}

header {

position: fixed;

height: 50px;

left: 0;

right: 0;

top: 0;

}

footer {

position: fixed;

height: 34px;

left: 0;

right: 0;

bottom: 0;

}

main {

/* main绝对定位,进行内部滚动 */

position: absolute;

top: 50px;

bottom: 34px;

/* 使之可以滚动 */

overflow-y: scroll;

}

main .content {

height: 2000px;

}

这样就可以解决问题了。在原始输入法下, fixed 元素可以定位在页面的正确位置。滚动页面时,由于滚动的是 main 内部的 div,因此 footer 不会跟随页面滚动。

上面貌似解决了问题,但是如果在手机上实际测试一下,会发现 main 元素内的滚动非常不流畅,滑动的手指松开后,滚动立刻停止,失去了原本的流畅滚动特性。百度一下弹性滚动的问题,发现在 webkit 中,下面的属性可以恢复弹性滚动。

                      -webkit-overflow-scrolling: touch;  在 main 元素上加上该属性后,滑动流畅。

6.扩展思考

安卓下会出现这种情况怎么解决?

android 解决思路基本一样,由于 fixed 在软键盘唤起后会失效,导致在页面可以滚动时,会跟随页面一起滚动。因此如果页面无法滚动,那么 fixed 元素即使失效,也不会滚动,也就不会出现 bug 了。

感谢大家观看

BY : 聂义中

你可能感兴趣的:(fixed布局在移动端出现的问题及解决方案)