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

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

本文主要内容 1、导航是什么 2、导航的实现方法 3、小结 1、条导航是什么 如图: 导航栏的初始位置一般是靠近在页面的顶部位置,但是又存在一定距离,通常这块区域放置最为醒目或者重要元素的地方...明白了导航条的基本效果,下面写个简单的demo吧。 2、导航的实现方法 一、样式结构搭建 考虑到触发功能,需要为导航条设置触发后的样式。 HTML5学堂是一个热爱H5的讲师组成的组织,致力于构建一个前端、HTML5的分享平台,能够给学生提供一些资料,也为广大前端爱好者提供一个分享平台,其中涉及到的基本知识,JS...底层知识,JS底层知识,面试真题、相关技术、未来发展等。...: 3、小结 导航的交互方式极大的提高了用户体验,是电商网站网站最常用的交互效果之一,希望本文能给大家带来一些帮助。

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

纯CSS实现吸附效果

前言 「吸附效果」就是网页滚到到某个位置,元素固定在该位置,后续不随网页滚动而滚动。吸附效果很常见,譬如效果效果,经常用在跟随导航、移动广告和悬浮提示等场景中。...原理 在jQuery时代就有很多吸附效果插件了,现在常用的三大前端框架也有自身第三方的吸附效果组件。...JS实现吸附效果的代码在网上一搜一大堆,更何况笔者喜欢耍CSS,在此就不贴相关的JS代码了。本文为各位同学推荐一个很少见很少用的CSS属性:position:sticky。...上述Demo里5个节点都声明了position:sticky,但由于top/bottom赋值有所不同就产生了不同的吸附效果。 ?...有吸附效果需求的同学建议一试,要兼容IExplorer就算了。 ? 兼容性

3.8K20

页面中元素的

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

1.2K30

移动端fixbar解决方案

需求背景 经常会有这样的需求,当页面滚动到某一个位置时,需要某个页面元素固定在屏幕顶部,并且有时需要连续滚动。...问题 position:fixed给移动端带来的问题: IOS8在页面滚动时,顶不连续;页面滑动时,不见,页面滚动停止后,缓慢出现 滚动到顶部之后,会出现两个一样的, 过一会才恢复正常。...footer底部输入框 focus 状态,footer 底部输入框被居中,而不是吸附在软键盘上部。...安卓 滚动距离超过某位置时,js动态设置样式;为了防止惯性滚动引起的fix不及时的情况,在 touchstart、 touchmove 、 touchend 事件都进行监听。...setTimeout(scrollHandler, 1000); }); } 不支持sticky 如果浏览器不支持position:sticky,那么就使用js

2.9K30

效果解决方案

页面向下滚动超过元素初始位置时,把元素固定在顶部 要求的元素一般是二级导航栏、搜索框、文章标题栏(h1)、表头(thead)、tab条等等,共同特点是在内容或功能上比较重要,但又不是最重要的元素...监听滚动判断位置的方法完全失效,平滑效果变成了滚过临界位置直到停止滚动时,元素跳到目标位置,体验非常差,不可忍受 scroll不能用,但还可以有一些奇怪的思路,比如定时器读scrollTop,touchmove...,比Android scroll方案体验更平滑,但限制很明显,无法实时获知状态,于此相关的各种效果都受限制,比如tab列表: sticky-tab 非状态时可以划动列表部分,让页面滚动,转到状态...,多个tab列表无缝切换,浏览状态互不影响 状态时划动当前tab列表,到头,让页面滚动,转到非状态 也就是说,非状态时,让tab列表不能滚动(overflow-y: hidden);状态时...:Android用scroll方案,在效果可接受范围内手动节流,提升性能;IOS用CSS sticky,如果不需要兼容IOS 8-以及任意版本UIWebView的话,也可以采用scroll方案 tab

3.3K10

RecyclerView 居然还能实现效果

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

2.9K20

基于 Vue 的两层踩坑总结

废话不多说,先看一下两层的最终实现效果,如下图所示。 ?...图片.gif 功能点:两层,因为 Tabs 区域比较长所以在滚动过程中点击一层 Tabs 会回弹至一层的位置,这个功能点和锚点有些类似。...二层 Tabs 通过 hover 切换,没有回弹效果。...主要原因:第一层还符合条件,第二层已经开始消失 解决方案:给第一层元素添加 minHeight 属性,其大小为第一层元素的高度与第二层元素的高度的和。...position 值为 static 即可 ◎ “变形” 同样 DOM 结构的元素,在 IE 浏览器中,会变形 查看 vue-sticky 的源码,发现 position:fixed; 是设置在要的元素的第一个子元素上

1.4K20

带你造轮子,自定义一个随意拖拽可边的View

1、效果 2、前言 在开发中,随意拖拽可边的悬浮View还是比较常见的,这种功能网上也有各种各样的轮子,其实写起来并不复杂,看完本文,你也可以手写一个,而且不到400行代码就能实现一个通用的随意拖拽可边的悬浮...比如默认在顶部,向下滑动的距离不足半屏,那就还是吸附在顶部,超过半屏,则自动吸附在底部,左右同理。...4.3.1、上下边 计算公式: 1.上半屏: 1.1.滑动距离<半屏= 1.2.滑动距离>半屏=底 2.下半屏: 2.1.滑动距离<半屏=底 2.2.滑动距离>半屏= 先看下效果: 可以看到基础效果我们已经实现了...(event.rawY - mFirstY) if (centerY < getScreenHeight() / 2) { //滑动距离<半屏=...计算公式: 1.左半屏: 1.1.滑动距离<半屏=左 1.2.滑动距离>半屏=右 2.右半屏: 2.1.滑动距离<半屏=右 2.2.滑动距离>半屏=左 看下效果: 左右边的效果相对上下边来说要简单些

51610

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

前言 我入职第二家公司接到的第一个需求就是修复之前外包做的滚动效果。...后来在项目中总会遇到滚动效果需要实现,现在我将我知道的 4 种滚动实现方式做详细介绍。...我们一定需要使用 scrollTop-offsetTop 的值来实现滚动效果吗?答案是否定的。 我们一同看看第四种方案。...解决方案 为这个元素添加一个等高的父元素,我们监听这个父元素的 getBoundingClientRect().top值来实现效果,即: <div class="title_box" ref="...描述: 当页面往下滚动时,<em>吸</em><em>顶</em>元素需要等页面滚动停止之后才会出现<em>吸</em>顶<em>效果</em> 当页面往上滚动时,滚动到<em>吸</em><em>顶</em>元素恢复文档流位置时<em>吸</em><em>顶</em>元素不恢复原样,而等页面停止滚动之后才会恢复原样 原因:在 ios 系统上不能实时监听

2.4K60

探究 position-sticky 失效问题

CSS 的 position 值中,有一个非常有用的值 -- position: sticky,通常会被用于各种底,边的效果中。...其实,这里不算失效,我们只需要将包裹 .sticky 元素的父容器的高度设置的大于 .sticky 元素本身,也能看到效果。...其实,造成这种现象的本质原因是,设置了 position: sticky 的元素吸附的基准元素从 .container 变成了 .parent 。...原因在于,设置了 overflow: hidden 的元素,它不再代用滚动的特性,当 sticky元素吸附于.hidden元素的顶部时,它随着 .hidden` 元素本身在 container 移动。...(当然,此时,sticky 吸附的基准元素就会变成父元素) 最后 好了,本文到此结束。 更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。

4.5K20
领券