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 网页下拉菜单代码解释 中文翻译
Feb 27 HTML / CSS
CSS3支持IE6, 7, and 8的边框border属性
Dec 28 HTML / CSS
CSS3制作气泡对话框的实例教程
May 10 HTML / CSS
用CSS3实现无限循环的无缝滚动的示例代码
Nov 01 HTML / CSS
简单几步用纯CSS3实现3D翻转效果
Jan 17 HTML / CSS
CSS3 实现弹跳的小球动画
Oct 26 HTML / CSS
用HTML5实现鼠标滚轮事件放大缩小图片的功能
Jun 25 HTML / CSS
HTML5 文件上传下载的实例代码
Jul 03 HTML / CSS
html5超简单的localStorage实现记住密码的功能实现
Sep 07 HTML / CSS
HTML5新标签兼容——&gt; 的两种方法
Sep 12 HTML / CSS
浅析图片上传及canvas压缩的流程
Jun 10 HTML / CSS
HTML页面中使两个div并排显示的实现
May 15 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
中国的第一台收音机
2021/03/01 无线电
php date与gmdate的获取日期的区别
2010/02/08 PHP
discuz的php防止sql注入函数
2011/01/17 PHP
ThinkPHP3.1新特性之字段合法性检测详解
2014/06/19 PHP
Yii框架引入coreseek分页功能示例
2019/02/08 PHP
javascript 硬盘序列号+其它硬件信息
2008/12/23 Javascript
jquery 触发a链接点击事件解决方案
2013/05/02 Javascript
什么是Node.js?Node.js详细介绍
2014/06/01 Javascript
js实现仿Discuz文本框弹出层效果
2015/08/13 Javascript
异步JS框架的作用以及实现方法
2015/10/29 Javascript
JS获取及验证开始结束日期的方法
2016/08/20 Javascript
原生JS实现图片轮播与淡入效果的简单实例
2016/08/21 Javascript
浅谈jquery高级方法描述与应用
2016/10/04 Javascript
详解jQuery中的事件
2016/12/14 Javascript
详解vue-router 2.0 常用基础知识点之router.push()
2017/05/10 Javascript
详解ionic本地相册、拍照、裁剪、上传(单图完全版)
2017/10/10 Javascript
如何将你的AngularJS1.x应用迁移至React的方法
2018/02/01 Javascript
详解各版本React路由的跳转的方法
2018/05/10 Javascript
解决$store.getters调用不执行的问题
2019/11/08 Javascript
jQuery 图片查看器插件 Viewer.js用法简单示例
2020/04/04 jQuery
[01:43]倾听DOTA2英雄之声 魅惑魔女国服配音鉴赏
2013/06/06 DOTA
python使用opencv读取图片的实例
2017/08/17 Python
django开发教程之利用缓存文件进行页面缓存的方法
2017/11/10 Python
使用python的pexpect模块,实现远程免密登录的示例
2019/02/14 Python
Python函数定义及传参方式详解(4种)
2019/03/18 Python
python模拟斗地主发牌
2020/04/22 Python
清除canvas画布内容(点擦除+线擦除)
2020/08/12 HTML / CSS
Bugatchi官方网站:男士服装在线
2019/04/10 全球购物
运动鞋、足球鞋和慕尼黑球衣:Sport Münzinger
2019/08/26 全球购物
4s店机修工岗位职责
2013/12/20 职场文书
党员违纪检讨书
2014/02/18 职场文书
市级优秀班主任事迹材料
2014/05/13 职场文书
委托书格式范文
2015/01/28 职场文书
整改通知书
2015/04/20 职场文书
哪类餐饮行业,最适合在高校创业?
2019/08/19 职场文书
nginx容器方式反向代理实战
2022/04/18 Servers