关闭

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

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

一:效果描述

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

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

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

关闭

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

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

css两端对齐——div+css布局实现2端对齐的4种方法总结

css两端对齐,通过margin负值、justify、space-between、column-count等多种方式来实现css的两端对齐。

css 浮动布局,清除浮动

浮动的特性:(1)浮动元素有左浮动(float:left)和右浮动(float:right)两种(2)浮动的元素会向左或向右浮动,碰到父元素边界、其他元素才停下来

使用flex实现5种常用布局

flex常用布局:经典的上-中-下布局。在上-中-下布局的基础上,加了左侧定宽 sidebar。左边是定宽 sidebar,右边是上-中-下布局。还是上-中-下布局,区别是 header 固定在顶部,不会随着页面滚动。左侧 sidebar 固定在左侧且与视窗同高,当内容超出视窗高度时,在 sidebar 内部出现滚动条。

flex布局,学习flex弹性布局总结

flex布局(Flexible Box)是对界面css盒模型的一个优化,适应不同尺寸的屏幕,被定义flex的容器可以控制子元素的排列方向和大小,能够用更简单清晰的代码来完成复杂的布局。

前端响应式布局

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

移动WEB开发-响应式布局

响应式开发原理就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的。响应式需要一个父级做为布局容器,来配合子级元素来实现变化效果。

基于jquery 横向/纵向 时间轴插件推荐

这篇文章主要整理一些关于基于jquery,实现横向/纵向时间轴的插件推荐:jquery.jqtimeline插件、timeline.js插件、Timeglider.js插件、Melon HTML5 、jQuery Timelinr、Timeline Porfolio

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

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

flex弹性布局

以下是弹性布局的一些知识点,很简单,易懂!元素一旦变为弹性布局的元素后,float,clear,vertical-align,text-align都失效,定位属性是有效的!接下来就是弹性布局的核心:弹性布局的属性。

点击更多...

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