判断元素是否在视口和元素相交

Posted 等风来

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了判断元素是否在视口和元素相交相关的知识,希望对你有一定的参考价值。

判断元素是否在视区内

function isElementInViewport (el) {
    var rect = el.getBoundingClientRect();
    return (
        rect.top >= 0 &&
        rect.left >= 0 &&
        rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */
        rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */
    );
}

计算两个元素的相交面积

function getIntersect(rect1,rect2){
    var minx = Math.max(rect1.left,rect2.left),
        miny = Math.max(rect1.top,rect2.top),
        maxx = Math.min(rect1.right,rect2.right),
        maxy = Math.min(rect1.bottom,rect2.bottom);
    if(minx > maxx || miny > maxy){
            return 0;
    }
    var deltaW= maxx - minx,
        deltaH = maxy - miny;

    return deltaW * deltaH;
}

 

以上是关于判断元素是否在视口和元素相交的主要内容,如果未能解决你的问题,请参考以下文章

前端必知:如何判断元素出现在视口内(性能优化涉及)

IntersectionObserver API

9.判断两个单链表是否相交

算法面试

元素离开视口时的交点观察者

817. Linked List Components - LeetCode