• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > Web移动端Fixed布局的解决方案

Web移动端Fixed布局的解决方案

作者:qq_25368263的博客 字体:[增加 减小] 来源:互联网 时间:2017-08-02

本文主要包含bug,移动,web等相关知识,qq_25368263的博客希望在学习及工作中可以帮助到您

iOS下的 Fixed + Input BUG现象

让我们先举个栗子,最直观的说明一下这个 BUG 的现象。 常规的 fixed 布局,可能使用如下布局(以下仅示意代码):


 

</header>

<!-- 可以滚动的区域 -->
<main>
    <!-- 内容在这里... -->
</main>

<!-- fixed定位的底部 -->
<footer>
    <input type="text" placeholder="Footer..."/>
    <button class="submit">提交</button>
</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 {
margin-top: 50px;
margin-bottom: 34px;
height: 2000px
}
然后看起来就是下面这个样子。拖动页面时 header 和 footer 已经定位在了对应的位置,目测没问题了。

但接下来问题就来了!如果底部输入框软键盘被唤起以后,再次滑动页面,就会看到如下图所示:

我们看到 fixed 定位好的元素跟随页面滚动了起来… fixed 属性失效了!

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

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

虽然 isScroll.js 可以很好的解决 fixed 定位滚动的问题,但是不在万不得已的情况下,我们尽量尝试一下不依赖第三方库的布局方案,以简化实现方式。这里抛砖引玉作为参考。

解决思路:

既然在 iOS 下由于软键盘唤出后,页面 fixed 元素会失效,导致跟随页面一起滚动,那么假如——页面不会过长出现滚动,那么即便 fixed 元素失效,也无法跟随页面滚动,也就不会出现上面的问题了。

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


 

</header>

<!-- 可以滚动的区域 -->
<main>
    <div class="content">
    <!-- 内容在这里... -->
    </div>
</main>

<!-- fixed定位的底部 -->
<footer>
    <input type="text" placeholder="Footer..."/>
    <button class="submit">提交</button>
</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;
在 main 元素上加上该属性,嗯,丝般顺滑的感觉又回来了!

main {
/* main绝对定位,进行内部滚动 */
position: absolute;
top: 50px;
bottom: 34px;
/* 使之可以滚动 */
overflow-y: scroll;
/* 增加该属性,可以增加弹性 */
-webkit-overflow-scrolling: touch;
}
另外,这里的 header 和 footer 使用的是 fixed 定位,如果考虑到更老一些的 iOS 系统不支持 fixed 元素,完全可以把 fixed 替换成 absolute 。测试后效果是一样的。

至此一个不依赖第三方库的 fixed 布局就完成了。

您可能想查找下面的文章:

  • Web移动端Fixed布局的解决方案
  • IE6的3像素 bug解决方案分享
  • IE6常见bug附解决方法
  • IE6,IE7,IE8 css bug搜集及浏览器兼容性问题解决方法汇总
  • IE6兼容性问题及IE6常见bug详细汇总
  • 浏览器兼容之旅第四站:IE常见Bug总结及修复方法—part2
  • 浏览器兼容之旅第三站:IE常见Bug总结及修复方法—part1
  • Firebug 调试器Web开发者应掌握12个初级使用技巧
  • 修复iPhone的safari浏览器上submit按钮圆角bug
  • SELECT在浏览器中相关Bug整理

相关文章

  • 2017-08-06一个css transform效果 很有图片的感觉
  • 2017-08-06css3打造一款漂亮的卡哇伊按钮
  • 2017-08-06CSS3制作炫酷带方向感应的鼠标滑过图片3D动画
  • 2017-08-06css3学习心得分享
  • 2017-08-06纯css制作带三角border篇(兼容所有浏览器)
  • 2017-08-06在ie7下css居中样式text-align:center;偏左问题解决方法
  • 2017-08-06基于css3实现漂亮便签样式
  • 2017-08-06CSS设计网页小技巧 100%的高度
  • 2017-08-06CSS实现定位元素居中的方法
  • 2017-08-06用纯CSS实现饼状Loading等待图效果

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • css div实现的遮罩层完美兼容IE6-IE9 FireFox
    • CSS中视觉语义不等于基于表现的类
    • 使用clrs.cc来进行炫酷的CSS调色
    • 深入解析CSS中margin属性的使用
    • div中内容上下居中小结
    • 如何让div+css兼容ie6 ie7 ie8 ie9和FireFox Chrome等浏览器
    • CSS3绘制圆角矩形的简单示例
    • 纯CSS实现的菱形导航菜单效果代码
    • 使用CSS格式化页面布局示例(附图)
    • css串联选择器和后代选择器使用方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有