3

我有以下代码

html

<div class="checker">
</div>
<div class="red boxes">
</div>
<div class="green boxes">
</div>
<div class="blue boxes">
</div>

css

.checker {
    width: 100px;
    height: 100px;
    border: 1px solid black; 
    position: fixed;
    top: 0;

}
.boxes {
    margin-top: 300px;
    width: 600px;
    height: 600px;
}
.red {
    background: red;
}
.green {
    background: green;
}
.blue {
    background: blue;
}

我如何将类“.checker”的背景颜色更改为“.boxes”的背景颜色,当它们通过滚动触摸“.checker”的底部边框时,使用jquery

例如:当.class red 到达class=".red .checker" 的底部边框时,".checker" 类的背景颜色应该变为红色。等我不明白如何做到这一点。请帮我。

jsfiddle

4

3 回答 3

1

这个 jsFiddle 展示了如何检测重叠,您可以使用它并扩展来更改类。http://jsfiddle.net/98sAG/

var overlaps = (function () {
    function getPositions( elem ) {
        var pos, width, height;
        pos = $( elem ).position();
        width = $( elem ).width();
        height = $( elem ).height();
        return [ [ pos.left, pos.left + width ], [ pos.top, pos.top + height ] ];
    }

    function comparePositions( p1, p2 ) {
        var r1, r2;
        r1 = p1[0] < p2[0] ? p1 : p2;
        r2 = p1[0] < p2[0] ? p2 : p1;
        return r1[1] > r2[0] || r1[0] === r2[0];
    }

    return function ( a, b ) {
        var pos1 = getPositions( a ),
            pos2 = getPositions( b );
        return comparePositions( pos1[0], pos2[0] ) && comparePositions( pos1[1], pos2[1] );
    };
})();

学分: jQuery 碰撞

于 2013-06-24T17:37:35.993 回答
1

您是否在询问类似 http://jsfiddle.net/98sAG 的问题,如果您想在发生碰撞时尝试触发它,可以使用 jQ 碰撞 API

于 2013-06-24T17:32:37.080 回答
0

也许这段代码会有所帮助:当兄弟元素重叠时有效检测

您可能可以简化代码以仅检查垂直位置。

于 2013-06-24T17:35:06.303 回答