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动画事件—webkitAnimationEnd与计时器time事件
Jan 31 HTML / CSS
CSS3的常见transformation图形变化用法小结
May 13 HTML / CSS
css3实现动画的三种方式
Aug 24 HTML / CSS
基于HTML5 Canvas 实现弹出框效果
Jun 05 HTML / CSS
webapp字号大小跟随系统字号大小缩放的示例代码
Dec 26 HTML / CSS
html5拖曳操作 HTML5实现网页元素的拖放操作
Jan 02 HTML / CSS
HTML5样式控制示例代码
Nov 27 HTML / CSS
H5混合开发app如何升级的方法
Jan 10 HTML / CSS
HTML5中form如何关闭自动完成功能的方法
Jul 02 HTML / CSS
canvas压缩图片以及卡片制作的方法示例
Dec 04 HTML / CSS
Ratchet 模态框的实现
Aug 19 HTML / CSS
CSS 鼠标点击拖拽效果的实现代码
Dec 24 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
JS 网站性能优化笔记
2011/05/24 PHP
PHP实现伪静态方法汇总
2016/01/13 PHP
微信公众号开发之文本消息自动回复php代码
2016/08/08 PHP
JQUERY操作JSON实例代码
2010/02/09 Javascript
js getBoundingClientRect() 来获取页面元素的位置
2010/11/25 Javascript
裁剪字符串trim()自定义改进版
2013/04/10 Javascript
js获取url中&quot;?&quot;后面的字串方法
2014/05/15 Javascript
Firefox下无法正常显示年份的解决方法
2014/09/04 Javascript
JS倒计时代码汇总
2014/11/25 Javascript
浅谈JavaScript中运算符的优先级
2015/07/07 Javascript
原生js的RSA和AES加密解密算法
2016/10/08 Javascript
bootstrap导航条实现代码
2016/12/28 Javascript
jQuery实现字符串全部替换的方法【推荐】
2017/03/09 Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
2017/06/03 Javascript
JavaScript中的return布尔值的用法和原理解析
2017/08/14 Javascript
vue cli使用绝对路径引用图片问题的解决
2017/12/06 Javascript
详解小程序用户登录状态检查与更新实例
2019/05/15 Javascript
iview form清除校验状态的实现
2019/09/19 Javascript
js实现购物车商品数量加减
2020/09/21 Javascript
Taro小程序自定义顶部导航栏功能的实现
2020/12/17 Javascript
[46:09]2014 DOTA2华西杯精英邀请赛 5 25 LGD VS VG第三场
2014/05/26 DOTA
[53:49]LGD vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
深入理解python中的闭包和装饰器
2016/06/12 Python
django中的setting最佳配置小结
2017/11/21 Python
Python安装lz4-0.10.1遇到的坑
2018/05/20 Python
python初学者,用python实现基本的学生管理系统(python3)代码实例
2019/04/10 Python
python实现将两个文件夹合并至另一个文件夹(制作数据集)
2020/04/03 Python
移动Web—CSS为Retina屏幕替换更高质量的图片
2012/12/24 HTML / CSS
法国购买隐形眼镜和眼镜网站:Optical Center
2019/10/08 全球购物
Windows和Linux动态库应用异同
2016/04/17 面试题
2014年计算机专业个人自我评价
2014/01/19 职场文书
实验心得体会
2014/09/05 职场文书
合伙开公司协议书范本
2014/10/28 职场文书
会计稽核岗位职责
2015/04/13 职场文书
退税申请报告怎么写
2015/05/18 职场文书
追悼会答谢词范文
2015/09/29 职场文书