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使网页、图片变成灰色兼容大多数浏览器
Jul 02 HTML / CSS
CSS3属性box-shadow使用指南
Dec 09 HTML / CSS
CSS+jQuery实现的在线答题功能
Apr 25 HTML / CSS
浅谈HTML5 defer和async的区别
Jun 07 HTML / CSS
HTML5 Canvas实现文本对齐的方法总结
Mar 24 HTML / CSS
HTML5进度条特效
Dec 18 HTML / CSS
HTML5事件方法全部汇总
May 12 HTML / CSS
HTML5 表单验证失败的提示语问题
Jul 13 HTML / CSS
使用html2canvas.js实现页面截图并显示或上传的示例代码
Dec 18 HTML / CSS
Html5之自定义属性(data-,dataset)
Nov 19 HTML / CSS
html5默认气泡修改的代码详解
Mar 13 HTML / CSS
使用 CSS 轻松实现一些高频出现的奇形怪状按钮
Dec 06 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
php5.4传引用时报错问题分析
2016/01/22 PHP
Laravel框架实现调用百度翻译API功能示例
2019/05/30 PHP
表单提交时自动复制内容到剪贴板的js代码
2007/03/16 Javascript
来自chinaz的ajax获取评论代码
2008/05/03 Javascript
JavaScript 提升运行速度之循环篇 译文
2009/08/15 Javascript
JQuery 常用操作代码
2010/03/14 Javascript
Jquery树插件zTree用法入门教程
2015/02/17 Javascript
60行js代码实现俄罗斯方块
2015/03/31 Javascript
js原型链与继承解析(初体验)
2016/05/09 Javascript
微信小程序实现实时圆形进度条的方法示例
2017/02/24 Javascript
解决浏览器会自动填充密码的问题
2017/04/28 Javascript
jQuery实现拼图小游戏(实例讲解)
2017/07/24 jQuery
微信小程序 五星评分的实现实例
2017/08/04 Javascript
webpack构建的详细流程探底
2018/01/08 Javascript
js实现前面自动补全位数的方法
2018/10/10 Javascript
vue实现菜单切换功能
2019/05/08 Javascript
微信小程序用户授权、位置授权及获取微信绑定手机号
2019/07/18 Javascript
js实现图片上传到服务器和回显
2020/01/19 Javascript
解决vuex数据页面刷新后初始化操作
2020/07/26 Javascript
利用Python命令行传递实例化对象的方法
2016/11/02 Python
Python利用递归和walk()遍历目录文件的方法示例
2017/07/14 Python
对DJango视图(views)和模版(templates)的使用详解
2019/07/17 Python
Python Web框架之Django框架Model基础详解
2019/08/16 Python
Jupyter notebook无法导入第三方模块的解决方式
2020/04/15 Python
python能自学吗
2020/06/18 Python
推荐10个CSS3 制作的创意下拉菜单效果
2014/02/11 HTML / CSS
CPB肌肤之钥美国官网:Clé de Peau Beauté
2017/09/05 全球购物
SQL注入攻击的种类有哪些
2013/12/30 面试题
大四本科生的自我评价
2013/12/30 职场文书
《桃林那间小木屋》教学反思
2014/05/01 职场文书
品牌推广策划方案
2014/05/28 职场文书
信息管理专业自荐书
2014/06/05 职场文书
2014年个人债务授权委托书范本
2014/09/22 职场文书
债务纠纷委托书范本
2014/10/14 职场文书
提高系统的吞吐量解决数据库重复写入问题
2022/04/23 MySQL
ant design vue的form表单取值方法
2022/06/01 Vue.js