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教程(10):CSS3 HSL声明设置颜色
Apr 02 HTML / CSS
纯css3实现鼠标经过图片显示描述的动画效果
Sep 01 HTML / CSS
css3实现wifi信号逐渐增强效果实例
Aug 09 HTML / CSS
详解Sticky Footer 绝对底部的两种套路
Nov 03 HTML / CSS
CSS3改变浏览器滚动条样式
Jan 04 HTML / CSS
HTML5+CSS3实现无插件拖拽上传图片(支持预览与批量)
Jan 05 HTML / CSS
HTML5本地存储之Database Storage应用介绍
Jan 06 HTML / CSS
微信浏览器取消缓存的方法
Mar 28 HTML / CSS
HTML5标签嵌套规则详解【必看】
Apr 26 HTML / CSS
字中字效果的实现【html5实例】
May 03 HTML / CSS
HTML5 Web缓存和运用程序缓存(cookie,session)
Jan 11 HTML / CSS
在html页面中取得session中的值的方法
Aug 11 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
基于PHPExcel的常用方法总结
2013/06/13 PHP
phpmailer在服务器上不能正常发送邮件的解决办法
2014/07/08 PHP
对PHP新手的一些建议(PHP学习经验总结)
2014/08/20 PHP
使用PHPExcel操作Excel用法实例分析
2015/03/26 PHP
php实现过滤字符串中的中文和数字实例
2015/07/29 PHP
php 人员权限管理(RBAC)实例(推荐)
2017/05/24 PHP
ThinkPHP 5.1 跨域配置方法
2019/10/11 PHP
分享27个jQuery 表单插件集合推荐
2011/04/25 Javascript
Extjs中TabPane如何嵌套在其他网页中实现思路及代码
2013/01/27 Javascript
控制文字内容的显示与隐藏示例
2014/06/11 Javascript
JavaScript获取网页、浏览器、屏幕高度和宽度汇总
2014/12/18 Javascript
jQuery晃动层特效实现方法
2015/03/09 Javascript
JavaScript实现为指定对象添加多个事件处理程序的方法
2015/04/17 Javascript
jquery实现九宫格大转盘抽奖
2015/11/13 Javascript
bootstrap使用validate实现简单校验功能
2016/12/02 Javascript
template.js前端模板引擎使用详解
2017/10/10 Javascript
node文件批量重命名的方法示例
2017/10/23 Javascript
JavaScript创建对象的常用方式总结
2018/08/10 Javascript
vue 基于element-ui 分页组件封装的实例代码
2018/12/10 Javascript
详解vue 动态加载并注册组件且通过 render动态创建该组件
2019/05/30 Javascript
layui表格 列自动适应大小失效的解决方法
2019/09/06 Javascript
vue实现扫码功能
2020/01/17 Javascript
编写v-for循环的技巧汇总
2020/12/01 Javascript
[02:11]完美世界DOTA2联赛10月28日赛事精彩集锦:来吧展示实力强劲
2020/10/29 DOTA
[01:21]DOTA2 新英雄 森海飞霞
2020/12/18 DOTA
Python的print用法示例
2014/02/11 Python
python获取Linux下文件版本信息、公司名和产品名的方法
2014/10/05 Python
简单使用Python自动生成文章
2014/12/25 Python
django项目中使用手机号登录的实例代码
2019/08/15 Python
python 求定积分和不定积分示例
2019/11/20 Python
Pycharm pyuic5实现将ui文件转为py文件,让UI界面成功显示
2020/04/08 Python
PyTorch 导数应用的使用教程
2020/08/31 Python
一款纯css3实现的颜色渐变按钮的代码教程
2014/11/12 HTML / CSS
中英双版中文教师求职信
2013/10/27 职场文书
关于长城的导游词
2015/01/30 职场文书
经理聘任证明
2015/03/02 职场文书