首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS 导航,告别“回到顶部”

本文主要内容 1、导航是什么 2、导航的实现方法 3、小结 1、条导航是什么 如图: 导航栏的初始位置一般是靠近在页面的顶部位置,但是又存在一定距离,通常这块区域放置最为醒目或者重要元素的地方...明白了导航条的基本效果,下面写个简单的demo吧。 2、导航的实现方法 一、样式结构搭建 考虑到触发功能,需要为导航条设置触发后的样式。 <!...底层知识,JS底层知识,面试真题、相关技术、未来发展等。...二、功能添加 1.实现思路是监听 scroll 事件,判断当前页面的滚动位置,当滚动距离大于导航条距顶部的距离时,为导航条采用窗口定位。...2.与“回到顶部“的实现方法一样,但是会发现实现功能时,到了临界位置时,页面会抖动一下,因为当导航条fixed出去,下部内容填补了导航条离开的位置。抢占了导航条的位置,所以抖动了一下。

7.5K70
您找到你想要的搜索结果了吗?
是的
没有找到

页面中元素的

[需求] 滚动页面到顶部,实现某元素固定到顶部效果 点击某个按钮,页面滚动到相应的位置 滚动页面,当到达某个位置时,高亮对应的相关按钮 [元素实现方式] 关于元素顶效果,通过查阅相关资料和相关测试...: .sticky-box{ position: sticky; position: -webkit-sticky; top: 60px; //可通过js动态设置 } [3.兼容性] 通过查看...this.isFixed = scrollTop > offsetTop; } } [三、使用getBoundingClientRect().top] 还有一种更为直接的方式,可以实现顶效果...,就是使用getBoundingClientRect().top来获取元素相对于视口(浏览器窗口)的位置,相对于offsetTop,该方法不用考虑到元素的父级元素和页面滚动条的高度,直接对该元素进行处理即可...,不包含滚动的距离 this.offsetTop 表示的是元素距离顶部的条件值(一般项目需求是0) */ let tabOffsetTop = this.

1.2K30

【前端词典】4 种滚动实现方式的比较

后来在项目中总会遇到滚动的效果需要实现,现在我将我知道的 4 种滚动实现方式做详细介绍。...三、使用原生的 offsetTop 实现 我们知道 offsetTop 是相对定位父级的偏移量,倘若需要滚动的元素出现定位父级元素,那么 offsetTop 获取的就不是元素距离页面顶部的距离。...我们一定需要使用 scrollTop-offsetTop 的值来实现滚动的效果吗?答案是否定的。 我们一同看看第四种方案。...解决方案 为这个元素添加一个等高的父元素,我们监听这个父元素的 getBoundingClientRect().top值来实现顶效果,即: <div class="title_box" ref="...描述: 当页面往下滚动时,<em>吸</em><em>顶</em>元素需要等页面滚动停止之后才会出现<em>吸</em>顶效果 当页面往上滚动时,滚动到<em>吸</em><em>顶</em>元素恢复文档流位置时<em>吸</em><em>顶</em>元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听

2.4K60

一个Item的简单实现方法分享

一般的对于上图样式的Sticker我们使用CoordinatorLayout & AppBarLayout就可以说实现。 但是对于下面这种呢?...我的实现思路 首先整个页面的UI结构是通过RecyclerView实现的。 对于上面这个Sticker的实现是在布局的最上方添加了一个和RecyclerView中要的Item一模一样的布局。...上面的逻辑写的其实比较复杂,不过确实实现了需求(-_-), 我解释一下: 即我判断Sticker是否出现依赖于itemView.top和Sticker的前一个itemview: 如果当前的Sticker...则根据它itemView.top来判断它是否滚动到了顶部 如果它的前一个itemview已经不在RecyclerView中了(被回收了),那说明它肯定滚出去了,这时直接显示 上面的逻辑很奇怪,不过确实实现的需求...并且它的逻辑很简单,也很通用: 判断当前RecyclerView显示的第一个条目的位置是否大于StickerItem的位置,如果大于就展示Sticker 效果: 上面这种实现仅适用UI结构是RecyclerView

52320

移动端fixbar解决方案

需求背景 经常会有这样的需求,当页面滚动到某一个位置时,需要某个页面元素固定在屏幕顶部,并且有时需要连续滚动。...在PC端主要的实现是通过 CSS 的 position: fixed 属性,但是在移动端,尤其是在安卓端,存在诸多的兼容性问题。...问题 position:fixed给移动端带来的问题: IOS8在页面滚动时,顶不连续;页面滑动时,不见,页面滚动停止后,缓慢出现 滚动到顶部之后,会出现两个一样的, 过一会才恢复正常。...安卓 滚动距离超过某位置时,js动态设置样式;为了防止惯性滚动引起的fix不及时的情况,在 touchstart、 touchmove 、 touchend 事件都进行监听。...setTimeout(scrollHandler, 1000); }); } 不支持sticky 如果浏览器不支持position:sticky,那么就使用js

2.8K30

【前端词典】4 (+1)种滚动实现方式的比较

后来在项目中总会遇到滚动的效果需要实现,现在我将我知道的 4 种滚动实现方式做详细介绍。...三、使用原生的 offsetTop 实现 我们知道 offsetTop 是相对定位父级的偏移量,倘若需要滚动的元素出现定位父级元素,那么 offsetTop 获取的就不是元素距离页面顶部的距离。...我们一定需要使用 scrollTop-offsetTop 的值来实现滚动的效果吗?答案是否定的。 我们一同看看第四种方案。...解决方案 为这个元素添加一个等高的父元素,我们监听这个父元素的 getBoundingClientRect().top 值来实现顶效果,即: <div class="title_box" ref=...描述: 当页面往下滚动时,元素需要等页面滚动停止之后才会出现顶效果 当页面往上滚动时,滚动到元素恢复文档流位置时元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听

2K30

基于 Vue 的两层踩坑总结

废话不多说,先看一下两层的最终实现效果,如下图所示。 ?...图片.gif 功能点:两层,因为 Tabs 区域比较长所以在滚动过程中点击一层 Tabs 会回弹至一层的位置,这个功能点和锚点有些类似。...实现方式 本文主要通过 VueSticky 插件来实现实现步骤描述如下: 安装:npm install vue-sticky --save 引入: import VueSticky from...主要原因:第一层还符合条件,第二层已经开始消失 解决方案:给第一层元素添加 minHeight 属性,其大小为第一层元素的高度与第二层元素的高度的和。...图片懒加载 对于图片过多的页面,为了加速页面的加载速度,我们需要将页面内未出现在可视区域内的图片先不做加载, 等到滚动到可视区域后再去加载。

1.4K20

JS实现图片弹窗效果

中间磨磨唧唧从原生JS找到JS插件,浪费了不少精力和时间,但是也磕磕碰碰学到了些知识,建议读者:想学一下弹窗的JS实现代码的可以看看前两小节,只想实现效果的,直接复制源码就行!...一 点击鼠标实现弹出/隐藏图片 ? 实现原理:一个div做容器,里面包含了二维码图片,把标题(鼠标点击的目标)做一个onclick监听,用div的display属性控制图片的显示和隐藏。...实现原理:当点击标题链接onclick监听或者刷新网页时候,获取隐藏的二维码图片对象并弹出,点击关闭或者二维码图片外的区域则隐藏二维码图片display = "none"。类似上面例子原理。..., 关闭弹窗,实现点击空白处关闭图片 modal.onclick = function () { modal.style.display = "none"; //...利用jquery.popup.js可以实现图中炫酷的动画效果, 支持animate.css。

23.5K30

JS实现图片懒加载

懒加载的实现原理 由于网页中占用资源较多的一般是图片,所以我们一般实施懒加载都是对图片资源而言的,所以这里的实现原理主要是针对图片。...大家都知道,一张图片就是一个标签,而图片的来源主要是src属性。浏览器是否发起亲求就是根据是否有src属性决定的。...实现步骤及Demo 1.先介绍几个和懒加载相关的API document.documentElement.clientHeight//获取屏幕可视区域的高度 直观的图解: element.offsetTop...可能到这里还有一些人不知道怎么实现,我们还是用图来展示一下: 看了这张图,我们就得出了一个判断公式: 如果:offsetTop-scroolTop<clientHeight,则图片进入了可视区内,则被请求...2.代码实现 下面的代码就是根据以上公式实现的: <!

11.4K20

基于 Vue 的两层踩坑总结

废话不多说,先看一下两层的最终实现效果,如下图所示。 ?...图片.gif 功能点:两层,因为 Tabs 区域比较长所以在滚动过程中点击一层 Tabs 会回弹至一层的位置,这个功能点和锚点有些类似。...实现方式 本文主要通过 VueSticky 插件来实现实现步骤描述如下: 安装:npm install vue-sticky --save 引入: import VueSticky from...主要原因:第一层还符合条件,第二层已经开始消失 解决方案:给第一层元素添加 minHeight 属性,其大小为第一层元素的高度与第二层元素的高度的和。...图片懒加载 对于图片过多的页面,为了加速页面的加载速度,我们需要将页面内未出现在可视区域内的图片先不做加载, 等到滚动到可视区域后再去加载。

72710
领券