IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:Scroll事件

共 2 篇相关文章

IT 累计浏览 2,004

小tip: 子元素scroll父元素容器不跟随滚动JS实现

这篇讲的是前端开发中一个常见的交互痛点:当页面存在嵌套滚动容器时,子元素滚到底后,滚动事件会“冒泡”导致父容器继续滚动。作者从“萝卜蹲”的生动比喻出发,解析了这一浏览器默认行为的链条。 核心方案聚焦于PC端,利用JavaScript拦截鼠标滚轮事件(`mousewheel`或Firefox的`DOMMouseScroll`)。关键思路是:为子元素绑定滚轮事件监听器,当检测到滚动位置即将到达顶部(`scrollTop`为0)或底部(到达最大值)时,手动将滚动位置精确定位到边界,并立即调用`event.preventDefault()`阻止事件继续向上冒泡,从而“切断”父容器的滚动。 文章特别指出了IE浏览器的兼容性“坑”——它会在阻止前直接跳过边界。解决方案是在到达边界的前一次滚动时就介入处理,提前手动设置边界值。作者最终将方案封装成了一个简洁的jQuery插件`$.fn.scrollUnique()`,调用一行代码即可生效,并提供了可交互的在线演示。对于键盘等其他滚动触发方式,作者认为可按需扩展,但鼠标滚轮处理已覆盖主要场景。

IT 累计浏览 2,129

window resize和scroll事件的基本优化

这篇讲的是前端开发中一个常见的性能陷阱。文章从同事在项目中实际遇到的“翻车”现场切入:在低版本IE里,频繁触发的`resize`和`scroll`事件会导致页面卡死。问题的根源在于这两个事件触发频率极高,每次都同步执行复杂计算或DOM操作,会瞬间耗尽浏览器的性能资源。 作者的核心优化思路是“节流”:通过一个定时器,确保在设定的时间窗口(如400毫秒)内,无论事件被触发多少次,实际的处理函数只执行一次。代码示例清晰展示了如何用`setTimeout`和`clearTimeout`来实现这个简单的“节流阀”,这个方案对`resize`和`scroll`事件同样有效。 对于需要监听这些高频事件的场景,尤其是需要兼容老版本IE的项目,这个低成本、高收益的基础优化方法能有效避免页面假死,值得借鉴。