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 相关文章推荐
CSS去掉A标签(链接)虚线框的方法
Apr 01 HTML / CSS
一款利用纯css3实现的win8加载动画的实例分析
Dec 11 HTML / CSS
CSS3实现同时执行倾斜和旋转的动画效果
Oct 27 HTML / CSS
CSS3实现莲花绽放的动画效果
Nov 06 HTML / CSS
5分钟弄清楚html5的drag and drop(小结)
Apr 10 HTML / CSS
HTML5上传文件显示进度的实现代码
Aug 30 HTML / CSS
HTML5之SVG 2D入门5—颜色的表示及定义方式
Jan 30 HTML / CSS
移动端解决悬浮层(悬浮header、footer)会遮挡住内容的3种方法
Mar 27 HTML / CSS
html2 canvas生成清晰的图片实现打印功能
Sep 23 HTML / CSS
吃透移动端 Html5 响应式布局
Dec 16 HTML / CSS
Html5 Canvas实现图片标记、缩放、移动和保存历史状态功能 (附转换公式)
Mar 18 HTML / CSS
使用CSS3实现按钮悬停闪烁动态特效代码
Aug 30 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/03 冲泡冲煮
超级简单的发送邮件程序
2006/10/09 PHP
用PHP实现小型站点广告管理
2006/10/09 PHP
基于php导出到Excel或CSV的详解(附utf8、gbk 编码转换)
2013/06/25 PHP
thinkphp 验证码 的使用小结
2017/05/07 PHP
JavaScript 更严格的相等 [译]
2012/09/20 Javascript
js string 转 int 注意的问题小结
2013/08/15 Javascript
jQuery 获取和设置select下拉框的值实现代码
2013/11/08 Javascript
基于jquery实现的文字淡入淡出效果
2013/11/14 Javascript
js/jquery判断浏览器的方法小结
2014/09/02 Javascript
JavaScript判断IE版本型号
2015/07/27 Javascript
jQuery弹出div层过2秒自动消失
2016/11/29 Javascript
半个小时学json(json传递示例)
2016/12/25 Javascript
如何利用JQuery实现从底部回到顶部的功能
2016/12/27 Javascript
JS非空验证及邮箱验证的实例
2017/08/11 Javascript
原生JavaScript来实现对dom元素class的操作方法(推荐)
2017/08/16 Javascript
浅谈Webpack下多环境配置的思路
2018/06/27 Javascript
详解如何解决vue开发请求数据跨域的问题(基于浏览器的配置解决)
2018/11/12 Javascript
Vue渲染过程浅析
2019/03/14 Javascript
layui的表单验证支持ajax判断用户名是否重复的实例
2019/09/06 Javascript
vue实现数字滚动效果
2020/06/29 Javascript
Python如何处理大数据?3个技巧效率提升攻略(推荐)
2019/04/15 Python
Python操作MySQL数据库的示例代码
2020/07/13 Python
用CSS3和table标签实现一个圆形轨迹的动画的示例代码
2019/01/17 HTML / CSS
小学生自我鉴定
2013/10/12 职场文书
本科生求职简历的自我评价
2013/10/21 职场文书
网站开发实习生的自我评价
2013/12/11 职场文书
高中英语教学反思
2014/02/04 职场文书
计算机网络工程专业职业生涯规划书
2014/03/10 职场文书
副董事长岗位职责
2014/04/02 职场文书
禁毒宣传工作方案
2014/05/23 职场文书
家庭教育的心得体会
2014/09/01 职场文书
小学生竞选班干部演讲稿(5篇)
2014/09/12 职场文书
2016年秋季趣味运动会开幕词
2016/03/04 职场文书
CSS 伪元素::marker详解
2021/06/26 HTML / CSS
Python爬虫入门案例之爬取二手房源数据
2021/10/16 Python