JQuery实现的固定位置下拉隐藏上拉显示悬浮导航菜单

更新日期: 2018-05-09阅读量: 3450标签: 布局

一:效果描述

1、页面打开时,导航栏悬浮的页面上部 
2、页面向下拉的时候导航栏隐藏 
3、页面向上拉的时候导航栏出现


二:原理讲解

​ 页面打开时,先获取到页面的滚动条的初始高度(也可直接设为0),作用是初始化一个值,用于后面事件触发后进行判断。

​ 再获取导航栏的高度,作用是在初始位置进行下拉页面后,在什么时候触发导航栏隐藏。

​ 最后写滚动条触发函数

初始位置:页面打开时的位置


三:事件函数讲解

​ 事件触发后,首先判断事件发生后滚动条的高度与导航栏的高度。 
当判断为True时,导航条隐藏;当判断为False时,导航条出现

​ 然后判断本次事件导航条的高度与上次事件导航条的高度。 
当上次高度,低于本次高度,说明用户在看下面的内容,导航栏隐藏 
当上次高度,高于本次高度,说明用户在看上面的内容,导航栏出现


四:JQuery实现代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        /* 导航栏样式 */
        .navigation{
            width: 100%;
            height: 50px;
            background-color: #ac0e63;
            position: fixed;          /* 绝对定位(根据游览器边框定位) */
            left:0;
            top: 0;
            transition: top 0.5s;     /* 动画效果,top:显示的效果, 1s:是效果产生所花费的时间*/
        }

        /* 隐藏效果 */
        .hide{
            top: -60px;
        }

        /* 内容栏样式 */
        .content{
            width: 80%;
            height: 5000px;
            margin: 60px auto;
            background-color: #00a8a8;
        }

    </style>
</head>
<body>

    <div class="navigation"></div>
    <div class="content"></div>

    <script src="jquery-3.3.1.js"></script>
    <script>

        $(function(){
            var page_heig = $(document).scrollTop();            /* 初始化。用于第一次获取滚动条的高度 */
            var navigation = $('.navigation').outerHeight();    /* 获取该元素的高度 */

            $(window).scroll(function() {                       /* 滚动条触发事件 */
                var real_heig = $(document).scrollTop();        /* 事件触发后获取滚动条高度 */

                if (real_heig > navigation){                    /* 触发后的高度 与 元素的高度对比 */
                    $('.navigation').addClass('hide');          /* True 添加隐藏属性 */
                }else {
                    $('.navigation').removeClass('hide');       /* False 删除隐藏属性 */
                }

                if (real_heig < page_heig){                     /* 触发后的高度 与 上次触发后的高度 */
                    $('.navigation').removeClass('hide');       /* True 删除隐藏属性 */
                }
                page_heig = $(document).scrollTop();            /* 再次获取滚动条的高度,用于下次触发事件后的对比 */
             });
        });

    </script>
</body>
</html>


原文来源:https://blog.csdn.net/q627794135/article/details/80240627



站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: https://www.fly63.com/article/detial/747

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

需要把导航固定在底部?只能滑动内容,导航菜单固定不动的。这篇文章主要讲解三种实现方案,包括:fixed,absolute,以及css3的flex布局。

关于display:flex碰上white-space nowrap 影响布局的问题

背景,做一个前面图片宽度固定,后面宽度自适应,使用到了flex布局,但是想让后面div里文字不换行,超出以点点表示时,这时布局就乱了,查了下,原来flex布局与white-space:nowrap有影响

移动端web自适应适配布局解决方案

100%还原设计图,要注意: 看布局,分析结构。感觉难点在于:1.测量精度(ps测量数据);2.文字的行高。自动适应屏幕宽度 :网页的宽度默认等于屏幕的宽度

理解css中Grid布局,在项目中如何实现grid页面布局

CSS中Grid是一种二维网格式布局方式,Grid是为了解决二维布局问题而创建的CSS模块。使用Gird的好处,Gird在浏览器的兼容性,Grid布局的示例源码...

css页面常用布局技巧

居中布局;水平居中(宽度自适应);垂直居中(高度自适应);水平垂直居中;多列布局;左边定宽,右边自适应;左边不定宽,右边自适应;等宽布局;等高布局

解决页面缩小时页面布局会乱的问题

给body加上一个min-width最小宽度,以px为单位,这样当页面变小时,当达到你所设置的最小宽度,body的宽度不再改变,超出的部分会用横向滚动条显示,其内所有元素的布局也不会受影响。

css圣杯布局的实现方式

css圣杯布局思路:外面一个大div,里面三个小div(都是浮动)。实现左右两栏宽度固定,中间宽度自适应。中间栏优先渲染。

css实现内容不相同的左右两个div等高

现在有两个div左右排列,但是两个div的内容不相同,如何设置两个div的css做到在两个div等高排列呢?下面是3种实现方法,觉得很有代表性,所以索性收藏起来。通过父元素设置 overflow:hidden

前端响应式布局

Responsive design,意在实现不同屏幕分辨率的终端上浏览网页的不同展示方式。通过响应式设计能使网站在手机和平板电脑上有更好的浏览阅读体验。

css之定位

定位是css当中一种操作html元素布局的方案;属性position:static:默认值,无特殊定位,对象遵循HTML原则;absolute:绝对定位,将对象从文档流中完全拖离出来;fixed:类似于绝对定位的方式.

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!