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实现背景模糊的三种方式
Mar 09 HTML / CSS
利用CSS3实现自定义滚动条代码分享
Aug 18 HTML / CSS
CSS3 简写animation
May 10 HTML / CSS
可以随进度显示不同颜色的css3进度条分享
Apr 11 HTML / CSS
使用css3实现超炫的loading加载动画效果
May 07 HTML / CSS
CSS3哪些新特性值得称赞
Mar 02 HTML / CSS
HTML5 Geolocation API的正确使用方法
Dec 04 HTML / CSS
html5中canvas学习笔记1-画板的尺寸与实际显示尺寸
Jan 06 HTML / CSS
HTML5之SVG 2D入门2—图形绘制(基本形状)介绍及使用
Jan 30 HTML / CSS
AmazeUI 模态窗口的实现代码
Aug 18 HTML / CSS
带你了解CSS基础知识,样式
Jul 21 HTML / CSS
CSS+HTML 实现顶部导航栏功能
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
php中随机显示图片的函数代码
2011/06/23 PHP
php生成二维码的几种方式整理及使用实例
2013/06/03 PHP
php 实现Hash表功能实例详解
2016/11/29 PHP
PHP cookie与session会话基本用法实例分析
2019/11/18 PHP
Javascript模板技术
2007/04/27 Javascript
javascript 打印页面代码
2009/03/24 Javascript
javascript中使用css需要注意的地方小结
2010/09/01 Javascript
浅析jQuery的链式调用之each函数
2010/12/03 Javascript
JavaScript高级程序设计(第3版)学习笔记 概述
2012/10/11 Javascript
jQuery实现简单的tab标签页效果
2016/09/12 Javascript
js制作支付倒计时页面
2016/10/21 Javascript
javaScript生成支持中文带logo的二维码(jquery.qrcode.js)
2017/01/03 Javascript
jQuery实现简易的输入框字数计数功能示例
2017/01/16 Javascript
Jquery实时监听input value的实例
2017/01/26 Javascript
Ionic + Angular.js实现验证码倒计时功能的方法
2017/06/12 Javascript
详谈ES6中的迭代器(Iterator)和生成器(Generator)
2017/07/31 Javascript
一文让你彻底搞清楚javascript中的require、import与export
2017/09/24 Javascript
老生常谈JS中的继承及实现代码
2018/07/06 Javascript
微信小程序开发之map地图组件定位并手动修改位置偏差
2019/08/17 Javascript
JS数组的高级使用方法示例小结
2020/03/14 Javascript
python中字符串前面加r的作用
2015/06/04 Python
详解Python编程中基本的数学计算使用
2016/02/04 Python
python实现基于SVM手写数字识别功能
2020/05/27 Python
PHP实现发送和接收JSON请求
2018/06/07 Python
浅谈pyqt5在QMainWindow中布局的问题
2019/06/21 Python
python实现倒计时小工具
2019/07/29 Python
python爬虫线程池案例详解(梨视频短视频爬取)
2021/02/20 Python
一款基于css3的动画按钮代码教程
2014/11/23 HTML / CSS
详解background属性的8个属性值(面试题)
2020/11/02 HTML / CSS
同学会邀请书大全
2014/01/12 职场文书
护理专科自荐书范文
2014/02/18 职场文书
意向书范文
2014/03/31 职场文书
基层党建工作简报
2015/07/21 职场文书
Nginx配置并兼容HTTP实现代码解析
2021/03/31 Servers
Javascript中的解构赋值语法详解
2021/04/02 Javascript
golang interface判断为空nil的实现代码
2021/04/24 Golang