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

时间: 2018-05-09阅读: 864标签: 布局

一:效果描述

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



html页面body与div之间产生空白解决方法

在做一个页面输出时发现body与div之间出现20px左右高度的空白,尝试多种方法无解,尤其是方法1也解决不了,后来发现原来是html文件编码格式问题造成的!css初始化,解决不了,就将html文件格式保存为utf-8编码格式,即问题完美解决

rem布局和vw布局的理解

rem是一个灵活的、可扩展的单位,由浏览器转化像素并显示。与em单位不同,rem单位无论嵌套层级如何,都只相对于浏览器的根元素(HTML元素)的font-size。css3中引入了一个新的单位vw,与视图窗口有关,vw表示相对于视图窗口的宽度,除了vw,还有vmin和vmax两个相关的单位。

css实现保持div的等宽高比

css如何实现高度height随宽度width变化保持比例不变呢?即给定可变宽度的元素,它将确保其高度以响应的方式保持成比例(即,其宽度与高度的比率保持恒定)。这里以 4:3 为例,通过2种方式来实现

vue实现瀑布流布局的组件/插件总汇

瀑布流作为当前比较流行的一种网页布局方式,在视觉上呈现出参差不齐、琳琅满目、唯美的视觉效果,该布局随着页面滚动,数据不断加载并附加至当前页面的尾部。这篇文章主要介绍关于vue框架中常使用的瀑布流组件

纯css实现瀑布流(multi-column多列及flex布局)

瀑布流的布局自我感觉还是很吸引人的,最近又看到实现瀑布流这个做法,在这里记录下,特别的,感觉flex布局实现瀑布流还是有点懵的样子,不过现在就可以明白它的原理了。纯css实现的瀑布流只能是一列一列的排布,所以还是得用js来实现瀑布流更符合我们常见的瀑布流

height百分比失效_解决css中height:100%失效的问题

为了让网页内容更好的适应各类屏幕尺寸,一般都需要用到height:100%。但是会发现,height百分比失效并没有生效,这是什么原因造成的呢,以及我们需要如何解决呢?

什么是BFC布局——浅析BFC布局的概念以及作用

BFC 可以简单的理解为某个元素的一个 CSS 属性,只不过这个属性不能被开发者显式的修改,拥有这个属性的元素对内部元素和外部元素会表现出一些特性,这就是BFC

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

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

前端布局方式汇总及概念浅析

前端布局方式汇总:普通/文档流 布局、 Float 布局、绝对布局、Grid 网格布局、CSS3 Flex 弹性盒子布局、静态布局、流式布局、 自适应布局、响应式布局...

css圣杯布局的实现方式

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

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

广告赞助文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯