7

divブラウザウィンドウに a が表示されているとき、たとえばスクロールされているときなど、JavaScript を実行する必要があります。どうすればそうすることができますか?

基本構造:

<div class='page1'></div>

<div class='page2'></div>

<div class='page3'></div>

<div class='page4'></div>

CSS:

div {
    float: left;
    height: 500px;
    width: 500px;
    margin: 50px 0;
    background: grey;
}

フィドル: http://jsfiddle.net/Q5BUe/1/

4

2 に答える 2

10

他の提供された質問/解決策と同様に、ここに完全な実装があります...

ロード時に、関数を実行して、表示されているdivに対応する色を割り当てます。jQueryスクロールハンドラーでは、引き続き関数を呼び出して新しい背景色を割り当てます。

http://jsfiddle.net/Q5BUe/5/

$(allInView);
$(window).scroll(allInView);


function isScrolledIntoView(elem) {
    var docViewTop = $(window).scrollTop();
    var docViewBottom = docViewTop + $(window).height();

    var elemTop = $(elem).offset().top;
    var elemBottom = elemTop + $(elem).height();

    return ((elemBottom <= docViewBottom) && (elemTop >= docViewTop));
}

function allInView() {

    if (isScrolledIntoView($(".page1"))) $(".page1").css("backgroundColor", "red");
    else $(".page1").css("backgroundColor", "grey");

    if (isScrolledIntoView($(".page2"))) $(".page2").css("backgroundColor", "green");
    else $(".page2").css("backgroundColor", "#333");

    if (isScrolledIntoView($(".page3"))) $(".page3").css("backgroundColor", "yellow");
    else $(".page3").css("backgroundColor", "#222");

    if (isScrolledIntoView($(".page4"))) $(".page4").css("backgroundColor", "blue");
    else $(".page4").css("backgroundColor", "#111");

}
于 2012-09-07T18:10:12.473 に答える
4

あなたがjQueryを使用していることを暗示しているので、次のようになる可能性があります

if($('#element').is(':visible'))
{
    //do your thing
}
于 2012-09-07T18:01:30.530 に答える