打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
前后端分离之让前端开发脱离接口束缚(mock)

需求:

需要把导航固定在底部?只能滑动内容,导航菜单固定不动的。效果如下:

这篇文章主要讲解三种实现方案,包括:fixed,absolute,以及css3的flex布局。

html结构如下:

<div class="box">    <div class="roll">滚动区域</div>    <footer>底部固定菜单</footer></div><!---公用样式---><style>html,body{    margin:0;padding:0;height:100%;width:100%;}footer{    background:#F2F3F6;max-width: 750px;width: 100%;height: 1rem;}</style>

  

 

方法一:使用fixed

.box{        .roll{            padding-bottom:1rem;         }	footer{		position:fixed;bottom:0;z-index:999;	}}

  

 

方法二:使用absolute  

.box{	position: relative;height: 100%;	.roll{		position: absolute;bottom:1rem;top: 0;overflow-y: scroll;-webkit-overflow-scrolling: touch;height: auto;	}	footer{		position: absolute;bottom:0;	}}

  

 

方法三:使用flex 

.box{	display:flex;display: -webkit-flex;height:100%;flex-direction:column;	.roll{		flex: 1; width: 100%;overflow-y: scroll;-webkit-overflow-scrolling: touch;height: auto;	}}

  

资源网站大全 https://55wd.com 我的007办公资源网站 https://www.wode007.com

总结

1、底部定位为fixed或absolute的时候,出现优先级别较低,导致被其他div覆盖的情况,那么这里就需要用到z-index,来让他成为最高级别,不至于被覆盖。

2、底部定位为fixed或absolute,存在输入框的时候,会出现如下情况:

ios:激活输入框时,底部不会弹出来(合理)。
Android:激活输入框时,底部会跟着输入框弹出来(不合理)  

传统解决办法:通常将底部设置为fixed,当激活输入框的时候,将底部定位改为relative,即可兼容ios和Android。

3、使用方法二或者方法三,需要设置-webkit-overflow-scrolling 属性。这样才能保证滚动区域的流畅性,-webkit-overflow-scrolling控制元素在移动设备上是否使用滚动回弹效果。

4、在部分浏览器中设置overflow-y: scroll;会出现滚动条,这时候我们需要全局定义如下样式:

::-webkit-scrollbar{//scroll滚动条设置        width: 0px; height: 0px; color: rgb(136, 0, 0);">#fff;  }

  

5、移动端推荐使用方法三的布局形式。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Web移动端Fixed布局的解决方案
移动端重构系列3
移动端web页面使用position:fixed问题总结
【转】让iframe在iOS设备手机浏览器上支持滚动
DIV上中下布局高度自适应的研究[转]
负边距(negative margin)实现自适应的div左右排版
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服