• 移动端H5固定底部导航菜单的三种布局实现


    需求:

    需要把导航固定在底部?只能滑动内容,导航菜单固定不动的。效果如下:

    这篇文章主要讲解三种实现方案,包括:fixed,absolute,以及css3的flex布局。

    html结构如下:

    <div class="box">
        <div class="roll">滚动区域</div>
        <footer>底部固定菜单</footer>
    </div>
    <!---公用样式--->
    <style>
    html,body{
        margin:0;padding:0;height:100%;100%;
    }
    footer{
        background:#F2F3F6;max- 750px; 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;  100%;overflow-y: scroll;-webkit-overflow-scrolling: touch;height: auto;
    	}
    }
    

      

    资源网站大全 https://55wd.com 我的007办公资源网站 https://www.wode007.com

    总结

    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滚动条设置
             0px; height: 0px; color: rgb(136, 0, 0);">#fff;  
    }
    

      

    5、移动端推荐使用方法三的布局形式。

  • 相关阅读:
    php-基于面向对象的MySQL类
    php-迭代创建级联目录
    php-删除非空目录
    php-递归创建级联目录
    linux 用户管理
    mysql 语法大全
    dos命令下修改mysql密码的方法
    对 linux init.d的理解
    linux 重启服务器命令
    校验软件包
  • 原文地址:https://www.cnblogs.com/ypppt/p/13322914.html
Copyright © 2020-2023  润新知