美文网首页IT修真院-前端
使用fixed的时候,在手机上看是否会有问题,怎么解决?

使用fixed的时候,在手机上看是否会有问题,怎么解决?

作者: 寡人yu | 来源:发表于2017-09-02 10:43 被阅读0次

大家好,我是IT修真院武汉分院第10期学员余佳贝,一枚正直善良的web程序员。

今天给大家分享一下,修真院官网css任务4,深度思考中的知识点——使用fixed的时候,在手机上看是否会有问题,怎么解决?

1.背景介绍

移动端业务开发,iOS下经常会有fixed元素和输入框(input元素)同时存在的情况。但是fixed元素在有软键盘唤起的情况下,会出现许多莫名其妙的问题。 下面我们就来一起分析在一个简单的有输入框情况下的fixed布局方案。

2.知识剖析

IOS下的fixed+input出现的bug现象

下面,我们举一个简单的例子来说明这个现象(以下是我们常用的fixed布局)

<header></header><main></main><footer>         <input type="text">         <button type="submit" value="提交"></footer>

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

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 {

margin-top: 50px;

margin-bottom: 34px;

height: 2000px

}

我们在手机上打开,拖动页面时 header 和 footer 已经定位在了对应的位置,目测没问题了。

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

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

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

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

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

4解决方案

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

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

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

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;

6 拓展思考

安卓下会出现这种情况吗,存在的话怎么解决?

谈到了 iOS ,也来简单说一下 Android 下的布局吧。

在 Android2.3+ 中,因为不支持 overflow-scrolling ,因此部分浏览器内滚动会有不流畅的卡顿。但是目前发现在 body 上的滚动还是很流畅的,因此使用第一种在 iOS 出现问题的 fixed 定位的布局就可以了。如果需要考虑 Android2.3 以下系统,因为不支持 fixed 元素,所以依然要需要考虑使用 isScroll.js 来实现内部滚动。

其实在 fixed 和输入框的问题上,基本思路就是: > 由于 fixed 在软键盘唤起后会失效,导致在页面可以滚动时,会跟随页面一起滚动。因此如果页面无法滚动,那么 fixed 元素即使失效,也不会滚动,也就不会出现 bug 了

7.参考文献

参考一:http://blog.csdn.net/ly2983068126/article/details/49306427"target="_blank">移动端Web页面使用fixed总结

参考二:http://www.grycheng.com/?p=1534"target="_blank">移动端position:fixed总结

8.更多讨论

1 fixed在各种浏览器中会有不同的表现么?

2 position:absolute/relative在移动端也会出现不同的现象么?

PPT


使用fixed的时候,在手机上看是否会有问题,怎么解决?_腾讯视频

相关文章

  • 使用fixed的时候,在手机上看是否会有问题,怎么解决?

    大家好,我是IT修真院武汉分院第10期学员余佳贝,一枚正直善良的web程序员。 今天给大家分享一下,修真院官网cs...

  • Unity 3D自动对焦

    问题 在使用Vuforia制作时候,导入安装包后,在手机上使用时候镜头会很模糊,往往连识别对象都看不清。 解决 根...

  • 移动端底部定位input框在苹果手机上面被遮挡问题

    当将input框用fixed定位在手机端底部的时候,在苹果手机上面会出现键盘遮挡input框的问题,但在安卓上面没...

  • oppo手机安装证书文件报错问题

    问题描述 Fiddler 在手机上安装https证书报错charles 在手机上安装https证书报错 解决办法 ...

  • (1). input placeholder问题 在手机上,placeholder内容明显靠上 解决办法: 不...

  • append 在手机上无法执行

    append 在手机上无法运行 描述:当在电脑上运行时可以正常执行,在手机上执行时会卡在此处解决: 使用js的ap...

  • 2016-12-3

    解决头部适配问题,但是使用了Position为fixed,所以当浏览器窗口缩小的时候虽有滚动条但是头部 不会随之滚动。

  • Android生产包,崩溃

    问题 今天打的生产包,在手机上安装就直接崩溃,但是直接在手机上DEBUG运行是可以的。 解决方法 方法很简单:将P...

  • 下厨房(一)---啫菜

    自从有了智能手机,什么问题都能在手机上找到解决方案:餐厅定位置,排队可以用手机;旅行酒店、机票手机上订;看新闻、写...

  • 用手机的碎片化时间玩转高效写作

    有个速写神器的新用户问我,能不能在手机上使用高效写作软件。 答案是肯定的,只要有问题,就有解决问题的方法。 我们这...

网友评论

    本文标题:使用fixed的时候,在手机上看是否会有问题,怎么解决?

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