JS 检查元素是否在视口内
最后更新: 2022-08-29
阅读时间: 1
min
前言 分享两个监测元素是否在视口内的方法
1. 位置计算
使用 Element.getBoundingClientRect()
方法返回元素相对于视口的位置
1 2 3 const isElementVisible = (el ) => { const rect = el.getBoundingClientRect(); };
1 2 3 4 5 const isElementVisible = (el ) => { const rect = el.getBoundingClientRect(); const vWidth = window .innerWidth || document .documentElement.clientWidth; const vHeight = window .innerHeight || document .documentElement.clientHeight; };
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 const isElementVisible = (el ) => { const rect = el.getBoundingClientRect() const vWidth = window .innerWidth || document .documentElement.clientWidth const vHeight = window .innerHeight || document .documentElement.clientHeight if ( rect.right < 0 || rect.bottom < 0 || rect.left > vWidth || rect.top > vHeight ) { return false } return true }
getBoundingClientRect
方法会使浏览器发生回流和重绘,性能消耗稍大,但兼容性比 Intersection Observer 要好。
2. Intersection Observer
The Intersection Observer API provides a way to asynchronously observe changes in the intersection of a target element with an ancestor element or with a top-level document’s viewport .
Intersection Observer API提供了一种异步检测目标元素与祖先元素或 viewport 相交情况变化的方法。在目标元素与视口或者其他指定元素发生交集时和触发配置的回调函数。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 const boxes = document .querySelectorAll('.box' )const observer = new IntersectionObserver((entries, observer ) => { entries.forEach((entry ) => { console .log( entry.target, entry.isIntersecting ? "visible" : "invisible" ); }); }) boxes.forEach((box ) => { observer.observe(box); });
示例
See the Pen
js check element in viewport by Cold Stone (@xrr2016 )
on CodePen .
参考 how-to-check-an-element-is-in-viewport-4bcl
Intersection Observer API