页面上下滚动改变顶部导航的定位方式
最近碰到设计师的一个设计效果要求,其他网站也有实现:
state1:当网页向下滚动时,页面header栏消失,顶部nav往上靠;
state2:当网页向上滚动时,页面header栏出现,顶部nav顺着nav往下靠。
页面已经含有以下功能:
1、弹窗弹出时,弹窗层可滚动,但页面层不允许滚动。此时,页面中的body元素和html元素的overflow样式属性都被设置成了hidden;
页面结构如下:
页面主体部分
页面底部
所碰到的问题是:scroll事件的监听太频繁(几乎移动一个像素就要执行一次监听事件),导致元素显示和隐藏时有闪动的问题,有时候甚至会导致某些元素来回切换。
在解决这样的问题的过程中,我的解决思路如下:
1、分别监听document的向下滚动和向上滚动事件
2、在监听的过程中,遇到弹窗弹出时不监听
3、在监听事件之外声明两个变量,分别为:permitMonitorScrollDown = true, permitMonitorScrollUp = true
4、
(1)、在监听document的向下滚动的流程中,在当前没有弹窗弹出的情况下,判断permitMonitorScrollDown的值是否为true,若为false,则直接return,跳出该监听流程;若为true,则将permitMonitorScrollDown设置为false,将状态切换到state1;设置定时器(js自带的setTimeout函数),在2000毫秒后恢复permitMonitorScrollDown为true。这种设置等价于每隔两秒允许监听一次向下滚动的事件。此处还隐藏有一点:当页面下滑,若切状态本身为state1时,不对状态做任何操作。
(2)、在监听document的向上滚动的流程中,在当前没有弹窗弹出的情况下,判断permitMonitorScrollUp的值是否为true,若为false,则直接return,跳出该监听流程;若为true,则将permitMonitorScrollUp设置为false,将状态切换到state2;设置定时器(js自带的setTimeout函数),在2000毫秒后恢复permitMonitorScrollUp为true。这种设置等价于每隔两秒允许监听一次向下滚动的事件。此处还隐藏有一点:当页面上滑,若切状态本身为state2时,不对状态做任何操作。
5、为了弥补上方两种情况发生的间歇期间页面滚动条已经触顶或者触底,所以需要用定时器单独处理这两种极端情况。
(1)、页面触顶(没有任何弹窗弹出且document的scrollTop为0),则状态必须切换到state1;
(2)、页面触底(没有任何弹窗弹出且document的scrollTop与$(window).height()的和刚好等于$(document).height()),则状态必须切换到state2;
我运用了jquery的filter函数,主要用于判断弹窗弹出时不监听滚动事件的情况(同时有一种等价的方式:当body的滚动条长度和滚动条本身的高度一样时,代表弹窗出现了。$("body")[0].scrollHeight==$(“body”).height()),同时运用了程序中排他锁的概念。
以上是页面上下滚动改变顶部导航的定位方式的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

手机屏幕不好滑动干涩的解决办法:1、给屏幕加湿;2、定期清洁屏幕;3、增加手指的滑动力度;4、使用手机膜;5、更换保护套;6、保持手部湿润;7、贴膜时处理干净;8、使用润滑剂;9、使用手套;10、调整屏幕亮度;11、更换手机。详细介绍:1、给屏幕加湿,在屏幕旁边放置一个加湿器或者喷一些水,让空气中的湿度增加,从而减少屏幕的干燥感;2、定期清洁屏幕,使用专业的屏幕清洁剂等等。

JavaScript如何实现图片的上下滑动切换效果并加入淡入淡出动画?在网页开发中,经常需要实现图片的切换效果,可以通过JavaScript来实现上下滑动切换,并且加入淡入淡出的动画效果,下面我们来具体了解一下。首先,我们需要一个包含多张图片的容器,可以使用HTML中的div标签来承载图片。例如,我们创建一个id为"image-container"的div来

JavaScript如何实现图片的上下拖动切换效果?随着互联网的发展,图片在我们生活和工作中扮演着重要的角色。为了提升用户体验,我们常常需要给图片增加一些特效或交互效果。其中,图片的上下拖动切换效果是一种很常见、简洁且实用的效果。本文将介绍如何使用JavaScript实现这一效果,并提供具体的代码示例。首先,我们需要创建一个HTML文件,来展示图片并实现拖

HTML、CSS和jQuery:实现滑动面板效果的技术指南随着移动设备的普及和Web应用的发展,滑动面板作为一种流行的交互方式,在网页设计中越来越常见。通过实现滑动面板效果,我们可以在有限的空间内展示更多的内容,提升用户体验。本文将详细介绍如何使用HTML、CSS和jQuery来实现滑动面板效果,并提供具体的代码示例。HTML结构首先,我们需要创建一个基本的

jQuery滑动事件解读:实现原理及注意事项在前端开发中,滑动事件是常见且常用的交互操作之一,通过滑动事件,我们可以实现诸如轮播图的切换、页面的滚动加载等功能。而jQuery作为一款流行的JavaScript库,提供了丰富的滑动事件处理方法,方便我们实现各种交互效果。本文将深入探讨jQuery中的滑动事件实现原理及注意事项,并提供具体的代码示例。一、实现原理

react实现滑动的方法:1、在onTouchStart事件找到touches,根据identifier中记录新的touch出现;2、在onTouchMove事件中根据identifier来记录每个touch经过的点的坐标;3、在onTouchEnd事件中,找到结束的touch事件,然后通过结束的touch事件划过的点来计算要执行的手势即可。

Vue是一个流行的JavaScript框架,它可以帮助我们更容易地构建交互式的Web应用程序。今天,我们将介绍如何使用Vue来创建一个滑动轮播图。我们将使用VueCLI来创建一个新的Vue项目,并使用Vue官方的轮播组件来实现滑动轮播图。以下是具体步骤:步骤1:安装VueCLI要安装VueCLI,您需要先安装Node.js。一旦您安装好了Node.js

在watchOS10.2中,您可以启用轻扫手势以更轻松地在AppleWatch表盘之间切换,就像您以前在watchOS9中所做的那样。继续阅读以了解它是如何完成的。如果您是AppleWatch的长期用户,您可能还记得曾经有一段时间可以通过简单的滑动手势在显示屏上切换表盘。这是watchOS9中的默认交互,但随后Apple在升级到watchOS10时删除了该手势。苹果之所以改变互动方式,是因为用户抱怨不小心更换表盘太容易了。但对于从未遇到过这个问题的人来说,苹果只是让事情变得更难——在滑动之前需要
