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

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

本文主要内容 1、吸顶导航是什么 2、吸顶导航的实现方法 3、小结 1、吸顶条导航是什么 如图: 吸顶导航栏的初始位置一般是靠近在页面的顶部位置,但是又存在一定距离,通常这块区域放置最为醒目或者重要元素的地方...当页面向下滚动时超过了吸顶导航的初始位置时,需要把吸顶导航栏固定在窗口顶部,一般吸顶导航栏还可以替换成文章标题栏,搜索框、tab条等等,例如百度糯米,天猫,淘宝最为常用。...明白了吸顶导航条的基本效果,下面写个简单的demo吧。 2、吸顶导航的实现方法 一、样式结构搭建 考虑到触发吸顶功能,需要为导航条设置触发后的样式。 HTML5学堂是一个热爱H5的讲师组成的组织,致力于构建一个前端、HTML5的分享平台,能够给学生提供一些资料,也为广大前端爱好者提供一个分享平台,其中涉及到的基本知识,JS...底层知识,JS底层知识,面试真题、相关技术、未来发展等。

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

    页面中元素的吸顶

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

    1.3K30

    基于 Vue 的两层吸顶踩坑总结

    图片.gif 功能点:两层吸顶,因为 Tabs 区域比较长所以在滚动过程中点击一层 Tabs 会回弹至一层吸顶刚吸顶的位置,这个功能点和锚点有些类似。...-- sticky wrapper, IMPORTANT --> CONTENT 看了 VueSticky 的源码后将该插件的实现原理简要概括如下:...主要原因:第一层吸顶还符合吸顶条件,第二层吸顶已经开始消失 解决方案:给第一层吸顶元素添加 minHeight 属性,其大小为第一层吸顶元素的高度与第二层吸顶元素的高度的和。...position 值为 static 即可 ◎ 吸顶“变形” 同样 DOM 结构的吸顶元素,在 IE 浏览器中,吸顶会变形 查看 vue-sticky 的源码,发现 position:fixed; 是设置在要吸顶的元素的第一个子元素上...这样子对于页面加载性能上会有很大的提升,也提高了用户体验,关于图片优化方面内容可以阅读我们团队另一篇文章 为你重新系统梳理下, Web 体验优化中和图有关的那些事(万字长文) 总结 本文简单的介绍了 VueSticky 插件的实现原理并分享了实战过程中出现的问题以及解决方案

    1.5K20

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

    我当时很纳闷为何一个滚动吸顶会有 bug,后来我查看代码才发现直接用的是 offsetTop 这个属性,而且并没有做兼容性处理。...后来在项目中总会遇到滚动吸顶的效果需要实现,现在我将我知道的 4 种滚动吸顶实现方式做详细介绍。...我们一定需要使用 scrollTop-offsetTop 的值来实现滚动吸顶的效果吗?答案是否定的。 我们一同看看第四种方案。...遇到的两个问题 一、吸顶的那一刻伴随抖动 出现抖动的原因是因为:在吸顶元素 position 变为 fixed 的时候,该元素就脱离了文档流,下一个元素就进行了补位。就是这个补位操作造成了抖动。...描述: 当页面往下滚动时,吸顶元素需要等页面滚动停止之后才会出现吸顶效果 当页面往上滚动时,滚动到吸顶元素恢复文档流位置时吸顶元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听

    2.5K60

    基于 Vue 的两层吸顶踩坑总结

    图片.gif 功能点:两层吸顶,因为 Tabs 区域比较长所以在滚动过程中点击一层 Tabs 会回弹至一层吸顶刚吸顶的位置,这个功能点和锚点有些类似。...-- sticky wrapper, IMPORTANT --> CONTENT 看了 VueSticky 的源码后将该插件的实现原理简要概括如下:...主要原因:第一层吸顶还符合吸顶条件,第二层吸顶已经开始消失 解决方案:给第一层吸顶元素添加 minHeight 属性,其大小为第一层吸顶元素的高度与第二层吸顶元素的高度的和。...position 值为 static 即可 ◎ 吸顶“变形” 同样 DOM 结构的吸顶元素,在 IE 浏览器中,吸顶会变形 查看 vue-sticky 的源码,发现 position:fixed; 是设置在要吸顶的元素的第一个子元素上...这样子对于页面加载性能上会有很大的提升,也提高了用户体验,关于图片优化方面内容可以阅读我们团队另一篇文章 为你重新系统梳理下, Web 体验优化中和图有关的那些事(万字长文) 总结 本文简单的介绍了 VueSticky 插件的实现原理并分享了实战过程中出现的问题以及解决方案

    76610

    自定义tab吸顶效果一(原理)

    PS:问题:什么是吸顶,吸顶有什么作用,吸顶怎么使用?...在很多app商城中,介绍软件的时候就会使用吸顶效果, 吸顶有很多作用,一个最简单粗暴的作用就是,让用户知道此刻在浏览哪个模块,并可以选择另外的模块,不需要再滑到顶部,有时我们在查看一个软件的简介的时候上拉布局...吸顶该怎么用呢,这里有一个简单的实现方法,在这期间有一个问题,是说ScrollViewd的滑动监听不能检测布局距离的问题,我查了写资料,说是在6.0之前的sdk不支持,但是可以自己重写方法。...实现原理:创建两个布局,这两个布局处于重叠状态,一个布局上面显示   背景为蓝色+导航栏+数据内容,注意这里的导航栏随着布局可移动,第二个布局显示导航栏但处于影藏状态,当滑动屏幕时,蓝色部分全部被拉上去后

    2.2K130

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

    后来在项目中总会遇到滚动吸顶的效果需要实现,现在我将我知道的 4 种滚动吸顶实现方式做详细介绍。...遇到的两个问题 一、吸顶的那一刻伴随抖动 出现抖动的原因是因为:在吸顶元素 position 变为 fixed 的时候,该元素就脱离了文档流,下一个元素就进行了补位。就是这个补位操作造成了抖动。...描述: 当页面往下滚动时,吸顶元素需要等页面滚动停止之后才会出现吸顶效果 当页面往上滚动时,滚动到吸顶元素恢复文档流位置时吸顶元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听...有的朋友或许会说这个我知道,可是这和滚动吸顶有什么关系呢? 不急,你是否还记得滚动吸顶使用了 offsetTop 或者 getBoundingClientRect().top 来获取响应的偏移量呢?...这样可以控制在一定时间内只读取 这里节流函数就直接是用 lodash.js 封装好的 throttle 方法。

    2.2K30

    导航栏滚动吸顶并自动高亮和点击跳转锚点

    2021-01-16 07:37:33 在阿里云的云市场页面上有一个效果,就是api导航栏当滚动条滚动到其所在位置时,自动吸顶,当滚动到下方所在导航栏指定的介绍时,自动高亮其导航栏。...我这次采用的是react来写,具体思路都是相同的,无论你用的是vue还是angular 还是使用jq还是原生js,都是一样的。...setNavList] = useState(navInfo);//这里使用自行构建的导航栏 const [fixNav,setFixNav] = useState(false);//用户标识什么时候导航栏吸顶...,另外增加了一个class为zhanfIx的地址,因为当导航栏吸顶时,此处会因为空出位置,下面内容上移,而产生不和谐的效果,我们需要在其吸顶的同时增加一个div来占位,以增加平滑的效果。...下面我们来看一下导航栏吸顶和滑动到指定位置导航栏高亮的逻辑。

    10.5K50

    吸顶效果解决方案

    一.场景 “吸顶”是一种比较老的交互方式,在PC页面已经用了很多年了,如图: sticky 吸顶元素的初始位置一般靠近页面顶部,但与顶部有一定距离,这块区域放的是最醒目的元素,比如Banner图...页面向下滚动超过吸顶元素初始位置时,把吸顶元素固定在顶部 要求吸顶的元素一般是二级导航栏、搜索框、文章标题栏(h1)、表头(thead)、tab条等等,共同特点是在内容或功能上比较重要,但又不是最重要的元素...所以需要配合默认图片占位符(base64)使用,或者偷懒先用min-height顶着,上方图片onload时再修正stickyT 三.移动端解决方案 从原理上看,直接搬过来是可以的。...,比Android scroll方案体验更平滑,但限制很明显,无法实时获知吸顶状态,于此相关的各种效果都受限制,比如吸顶tab列表: sticky-tab 非吸顶状态时可以划动列表部分,让页面滚动,转到吸顶状态...,多个tab列表无缝切换,浏览状态互不影响 吸顶状态时划动当前tab列表,到头,让页面滚动,转到非吸顶状态 也就是说,非吸顶状态时,让tab列表不能滚动(overflow-y: hidden);吸顶状态时

    3.6K10

    Python 小白的吸星大法

    听着颇有几分吸别人功力为己所用的味道,故自封"吸星大法"。 吸星大法 每个秘籍都有自己的前提,比如葵花宝典的"欲练此功,必先**"。咱这个没那么严苛,但是一定要学会去高效地搜索。...整个流程下来,我们自行搜索筛选结果,研读别人完整代码,模仿修改整合形成自己新代码,吸星大法也就练成了。 案例演练 正好前几天有朋友问到用 Python 实现计算器,我们就拿这个问题来演练下吸星大法。...False # 看了计算器的计算,比如1+2在输入+后,1还显示在屏幕上,输入了2之后,1就被替换了, 这个flag的作用就是这样的 self.char_top = '' # 保留栈顶的操作符号...self.num_top = 0 # 保留栈顶的数值 self.res = 0 # 保留计算结果,看计算器计算一次后,在继续按等号,还会重复最近一次的计算1+2,得到

    82630

    RecyclerView 居然还能实现吸底效果

    这些天遇到一个列表数据吸底需求,如果不满一屏就全部展示,如果超过一屏就让底部悬浮在屏幕底部。 大概效果如下图: ?...②如果h1小于h2,则说明RecyclerView内容高度超出屏幕,此时RecyclerView可滚动,所以我们需要在RecyclerView底部显示吸底的View。...原理示意图 RecyclerView控件的高度我们定义为h1,如下图所示: ?...ItemDecoration实现分组悬停原理 接下来我们来讲解如何使用ItemDecoration来实现底部View悬浮效果。...ItemDecoration实现吸底效果 我们的这个吸底效果跟分组悬停效果是有所不同的,分组悬停效果针对的是第一个可见的子View,吸底效果针对的是最后一个可见的子View。

    3.1K20
    领券