Html5移动端div固定到底部实现底部导航条的几种方式


Posted in HTML / CSS onMarch 09, 2021

需求:

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

Html5移动端div固定到底部实现底部导航条的几种方式

这篇文章主要讲解三种实现方案,包括: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;
    }
}

总结

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、移动端推荐使用方法三的布局形式。

到此这篇关于Html5移动端div固定到底部实现底部导航条的几种方式的文章就介绍到这了,更多相关Html5底部导航条内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
利用CSS3的线性渐变linear-gradient制作边框的示例
Jun 02 HTML / CSS
js实现移动端H5页面手指滑动刻度尺功能
Nov 16 HTML / CSS
详解Canvas事件绑定
Jun 27 HTML / CSS
使用HTML5技术开发一个属于自己的超酷颜色选择器
Sep 22 HTML / CSS
浅谈html5 响应式布局
Dec 24 HTML / CSS
利用HTML5绘制点线面组成的3D图形的示例
May 12 HTML / CSS
借助HTML5 Canvas API制作一个简单的猜字游戏
Mar 25 HTML / CSS
html5是什么_动力节点Java学院整理
Jul 07 HTML / CSS
HTML5中的Web Notification桌面右下角通知功能的实现
Apr 19 HTML / CSS
如何在Canvas中添加事件的方法示例
May 21 HTML / CSS
html5的pushstate以及监听浏览器返回事件的实现
Aug 11 HTML / CSS
从QQtabBar看css命名规范BEM的详细介绍
Aug 07 HTML / CSS
HTML5拖拽文件上传的示例代码
Mar 04 #HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
Feb 24 #HTML / CSS
Canvas在超级玛丽游戏中的应用详解
Feb 06 #HTML / CSS
Html5移动端网页端适配(js+rem)
Feb 03 #HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
Feb 03 #HTML / CSS
canvas版人体时钟的实现示例
Jan 29 #HTML / CSS
h5页面背景图很长要有滚动条滑动效果的实现
Jan 27 #HTML / CSS
You might like
如何使用微信公众平台开发模式实现多客服
2016/01/06 PHP
Yii2 rbac权限控制之rule教程详解
2016/06/23 PHP
Laravel 5.4向IoC容器中添加自定义类的方法示例
2017/08/15 PHP
详解PHP字符串替换str_replace()函数四种用法
2017/10/13 PHP
PHP创建文件及写入数据(覆盖写入,追加写入)的方法详解
2019/02/15 PHP
jquery 插件 人性化的消息显示
2008/01/21 Javascript
Extjs显示从数据库取出时间转换JSON后的出现问题
2012/11/20 Javascript
JavaScript中window.showModalDialog()用法详解
2014/12/18 Javascript
JQuery使用$.ajax和checkbox实现下次不在通知功能
2015/04/16 Javascript
jquery衣服颜色选取插件效果代码分享
2015/08/28 Javascript
在html中引入外部js文件,并调用带参函数的方法
2016/10/31 Javascript
jQuery自定义组件(导入组件)
2016/11/08 Javascript
jquery uploadify如何取消已上传成功文件
2017/02/08 Javascript
nodejs入门教程六:express模块用法示例
2017/04/24 NodeJs
JavaScript正则表达式校验与递归函数实际应用实例解析
2017/08/04 Javascript
Javascript中从学习bind到实现bind的过程
2018/01/05 Javascript
Vue中mintui的field实现blur和focus事件的方法
2018/08/25 Javascript
将Python的Django框架与认证系统整合的方法
2015/07/24 Python
深入理解python中函数传递参数是值传递还是引用传递
2017/11/07 Python
使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤
2018/12/17 Python
python字符串查找函数的用法详解
2019/07/08 Python
python实现将文件夹内的每张图片批量分割成多张
2019/07/22 Python
解决tensorflow训练时内存持续增加并占满的问题
2020/01/19 Python
在python里使用await关键字来等另外一个协程的实例
2020/05/04 Python
openCV提取图像中的矩形区域
2020/07/21 Python
印度婴儿用品在线商店:Firstcry.com
2016/12/05 全球购物
中东奢侈品市场:Coveti
2019/05/12 全球购物
自荐信要包含哪些内容
2013/11/06 职场文书
初三政治教学反思
2014/01/30 职场文书
自荐信的基本格式
2014/02/22 职场文书
试用期自我鉴定范文
2014/03/20 职场文书
公司大门门卫岗位职责
2014/06/11 职场文书
三峡大坝导游词
2015/01/31 职场文书
信贷客户经理岗位职责
2015/04/09 职场文书
大学副班长竞选稿
2015/11/21 职场文书
Java实现贪吃蛇游戏的示例代码
2022/09/23 Java/Android