吸顶效果是导航栏滚动至顶部后固定显示,核心为监听滚动事件并动态切换position: fixed状态;需用offsetTop获取初始位置、添加占位元素防页面跳动、CSS控制样式、requestAnimationFrame节流优化性能,并注意移动端兼容性。
吸顶效果就是当页面滚动到某个位置时,导航栏自动固定在页面顶部,不随滚动消失。核心是监听滚动事件,动态切换元素的 position: fixed 状态。
用 getBoundingClientRect() 或直接读取元素距页面顶部的距离(offsetTop),和 window.scrollY 对比。当滚动距离超过导航栏原始位置时,就给它加上固定类;反之移除。
offsetTop 获取初始位置,它不受父级 transform 影响,兼容性更稳element.classList.add/remove
JavaScript 只负责加/删 class,样式交给 CSS 控制:
position: relative 或 static,保持文档流位置position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
z-index 大于主要内容(如 1000)滚动事件触发频繁,直接在里面做 DOM 操作容易掉帧:
requestAnimationFrame 节流,确保样式更新只在下一帧执行throttle(例如 16ms 一次),比 debounce 更适合滚动场景offsetTop 提前缓存,不要每次滚动都重新读取IntersectionObserver 监听元素是否“离开视口”,但兼容性和精度不如手动计算稳定移动端屏幕窄、常有地址栏缩放,需额外注意:
resize 事件,窗口宽度变化时重新获取 offsetTop(尤其在横竖屏切换时)100vw,它可能包含滚动条宽度,导致横向溢出;改用 100% 更稳妥transform: translateZ(0) 或 -webkit-transform: translateZ(0) 可触发硬件加速缓解基本上就这些。不复杂但容易忽略占位和节流,上线前记得在真机上多滚几次看看效果。