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进行截取替代js的substring
Sep 02 HTML / CSS
CSS3圆角边框和边界图片效果实例
Jul 01 HTML / CSS
纯CSS3制作的鼠标悬停时边框旋转
Jan 03 HTML / CSS
html5+css3之制作header实例与更新
Dec 21 HTML / CSS
HTML5 canvas实现雪花飘落特效
Mar 08 HTML / CSS
分享全球十款超强HTML5开发工具
May 14 HTML / CSS
HTML5微信播放全屏问题的解决方法
Mar 09 HTML / CSS
html5 Canvas实现图片旋转的示例
Jan 15 HTML / CSS
HTML5 body设置自适应全屏
May 07 HTML / CSS
用position:sticky完美解决小程序吸顶问题的实现方法
Apr 24 HTML / CSS
CSS3 Tab动画实例之背景切换动态效果
Aug 23 HTML / CSS
使用CSS实现一个搜索引擎的原理解析
Sep 25 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
PHP 上传文件的方法(类)
2009/07/30 PHP
php 上传文件类型判断函数(避免上传漏洞 )
2010/06/08 PHP
通过缓存数据库结果提高PHP性能的原理介绍
2012/09/05 PHP
Thinkphp单字母函数使用指南
2016/05/08 PHP
php自定义函数转换html标签示例
2016/09/29 PHP
php常用正则函数实例小结
2016/12/29 PHP
详解PHP实现支付宝小程序用户授权的工具类
2018/12/25 PHP
根据分辨率不同,调用不同的css文件
2006/08/25 Javascript
JavaScript 特殊字符
2007/04/05 Javascript
JS 自动完成 AutoComplete(Ajax 查询)
2009/07/07 Javascript
移动端横屏的JS代码(beta)
2016/05/16 Javascript
jQuery实用小技巧_输入框文字获取和失去焦点的简单实例
2016/08/25 Javascript
微信小程序 解析网页内容详解及实例
2017/02/22 Javascript
原生JS实现移动端web轮播图详解(结合Tween算法造轮子)
2017/09/10 Javascript
微信小程序swiper组件用法实例分析【附源码下载】
2017/12/07 Javascript
使用vue2实现购物车和地址选配功能
2018/03/29 Javascript
解决nodejs的npm命令无反应的问题
2018/05/17 NodeJs
简单了解JavaScript中常见的反模式
2019/06/21 Javascript
Vue 防止短时间内连续点击后多次触发请求的操作
2020/11/11 Javascript
简单解决Python文件中文编码问题
2015/11/22 Python
python3实现暴力穷举博客园密码
2016/06/19 Python
python如何将图片转换为字符图片
2020/08/19 Python
解决pycharm无法识别本地site-packages的问题
2018/10/13 Python
python 读取竖线分隔符的文本方法
2018/12/20 Python
python爬虫 2019中国好声音评论爬取过程解析
2019/08/26 Python
python实现统计代码行数的小工具
2019/09/19 Python
pyecharts绘制中国2020肺炎疫情地图的实例代码
2020/02/12 Python
Python如何使用bokeh包和geojson数据绘制地图
2020/03/21 Python
Numpy中的数组搜索中np.where方法详细介绍
2021/01/08 Python
单身旅行者的单身假期:Just You
2018/04/08 全球购物
2015年纪委工作总结
2015/05/13 职场文书
高中语文教材(文学文化常识大全一)
2019/08/13 职场文书
MySQL 如何分析查询性能
2021/05/12 MySQL
MySQL连接查询你真的学会了吗?
2021/06/02 MySQL
Win11怎么启动任务管理器?Win11启动任务管理器的几种方法
2021/11/23 数码科技
MySQL数据库优化之通过索引解决SQL性能问题
2022/04/10 MySQL