首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS简易整页滚动

    fullPage超简易版本 1.知识点 JS 滚动监听事件 JS 移动端touch监听事件 函数节流 DOM操作 2.示例GIF ?...向下滚动时, 当 currentPosition 比 -整体分页高度 大时候(绝对值相比小时候), 向下滚动;向上滚动时, 当 currentPosition 大于 0 时候, 向上滚动. /...滚动事件firefox与其他浏览器事件不同, 所以需要进行判断. deltaY大于0时候, 想下滚动; 反之, 向上滚动. var handlerWheel = throttle(scrollMove...https://developer.mozilla.org/en-US/docs/Web/API/Element/mousewheel_event#The_detail_property // firefox页面滚动事件其他浏览器不一样...developer.mozilla.org/en-US/docs/Web/API/Element/mousewheel_event#The_detail_property // firefox页面滚动事件其他浏览器不一样

    15.6K31

    JS判断滚动条是否停止滚动

    背景:昨天一个同事有种需求,有一个展示数据区域div,带滚动条,当滚动滚动时,需要向后台发请求,计算数据,再拿到前台展示。        ...分析:由于数据量级别较大,所以当滚动滚动时,如果时时向后台发请求,对服务器和浏览器都造成巨大压力。想到解决方案是,当滚动条停止时,再去发请求计算数据。...那么问题来了,如何判断滚动条是否停止了呢?        解决:搜索了一下,js本身是无法判断滚动条是在滚动状态还是停止状态,只有通过其它方式了。...后来想到思路是当滚动滚动时候,发起一个定期执行方法,并记录一次当前滚动条到顶部距离,这个方法中判断此时滚动条到顶部距离是否和上次记录相等,如果相等,那么说明停止滚动了,不相等,还在滚动。...上次滚动条到顶部距离 interval = null;// 定时器 document.onscroll = function() { if(interval == null)// 未发起时,

    17.4K00

    js动画事件_JavaScript事件

    js之动画事件 首先,动画事件主要包括以下三个animationstart,animationiteration和animationend事件,下面做简单分别介绍。...animation主要有6个属性,分别来设置动画呈现出来哦效果,这个在我另一篇文章中有介绍,我这边简单展示一下。...animation:name duration timing-function delay iteration-count direction; 分别是:动画名称 动画持续事件 动画运行速度曲线 动画开始时运行时间...下面一段代码讲述是采用监听动画开始,动画再次播放和动画结束做出相应改变,这里用到addEventListener监听动画开始、动画持续播放、动画结束播放。 <!...如发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    18.4K10

    JS滑动滚动n种方式

    JS滑动滚动n种方式 # 阅读本文,你将: 了解原生JS实现页面滚动多种方式 了解这多种方式可以对应上效果以及推荐应用场景 多个滑动方面的坑以及相应(如果有)解决方案 获得一些有用函数...值: 如果为true,元素顶端将和其所在滚动可视区域顶端对齐。...那么,如果一个元素没有滚动条,采用是transform模拟滚动,那么就无效咯 2.3 适用性检测 可以用下边代码在控制台检测一下页面有没有任何一个地方代码scrollTop不是0 let elementList...区别是设置behavior为'smooth'后会平滑滚动 3.2 使用说明 如果场景要求我们滚动页面到某个元素位置,此时可以使用window.scrollTo(); 如果场景要求我们滚动到某个可滚动父元素位置...该api仅FireFox支持 7.1 基本用法 表示相对当前滚动位置再滚动指定页数距离,行为表现接近于空格键(反向+Shift)控制滚动 例如window.scrollByPages(-1)表示向上滚动

    6.3K10

    Js 事件委托(事件代理)

    一、概述 事件委托,又叫事件代理。事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型所有事件。 例子:有三个同事预计会在周一收到快递。...这里其实还有2层意思: 第一,现在委托前台同事是可以代为签收,即程序中现有的dom节点是有事件; 第二,新员工也是可以被前台MM代为签收,即程序中新添加dom节点也是有事件。...二、为什么是使用事件委托 一般来说,dom需要有事件处理程序,我们都会直接给它设事件处理程序就好了,那如果是很多dom需要添加事件处理呢?...,这就是为什么性能优化主要思想之一就是减少DOM操作原因;如果要用事件委托,就会将所有的操作放到js程序里面,与dom操作就只需要交互一次,这样就能大大减少与dom交互次数,提高性能; 每个函数都是一个对象...三、事件委托原理 事件委托利用事件冒泡原理,将事件绑定到父级元素上,当点击子元素时,通过事件冒泡将事件传递到父级元素。  四、总结: 那什么样事件可以用事件委托,什么样事件不可以用呢?

    11.4K30

    让 touch 系列事件触发滚动响应更快

    1写在前面 我们都知道,对于移动端网页而言,滚动是十分重要交互。 然而 touch 系列事件触发(滚动后)经常会引发严重性能问题。...这些都是很有用特性,能使处理( touch 系列)事件过程中,不会妨碍页面的正常滚动,然而开发者们有时候会觉得它们难以理解,更不会去使用。...为了解 touchstart 和 touchmove 使用(情况),我们添加了对这两个事件阻止滚动(发生)频率监控。...鉴于此问题严重性,我们意识到可以通过默认将这些事件监听器)设置为“被动”来提高滚动性能,而且基本不需要任何开发者修改代码。...在未来,我们希望默认为所有touchstart和touchmove事件监听器passive设置为true,并优化到(滚动响应)低于50ms。

    97220
    领券