3

我在页面上有两个滑块。第一个在页面加载时始终可见(在顶部),第二个在页面底部。

我需要使第二个滑块仅在可见时才开始播放(在滚动上)。我从开发人员那里得到了答案

(function() {
    var win, slider, sliderHeight, sliderPaused, winHeight;

    // Change the "revapi1" part here to whatever "revapi" name that your slider uses
    slider = revapi1.on('revolution.slide.onloaded', function() {

        win = jQuery(window).on('scroll', checkScroll).on('resize', sizer);
        sizer();

    });

    function sizer() {
        sliderHeight = slider.height();
        winHeight = win.height();
        checkScroll();
    }

    function checkScroll() {
        var scrTop = win.scrollTop(),
        offset = slider.offset().top;

        if(offset <= scrTop + winHeight && offset + sliderHeight >= scrTop) {

            if(sliderPaused) slider.revresume();
            sliderPaused = false;
        } else {
            if(!sliderPaused) slider.revpause();
            sliderPaused = true;
        }
    }
})();

我曾尝试使用此代码(我revapi1已更改为我的滑块 ID),但它似乎不起作用。

有没有人有一个可行的解决方案或者可以帮助我修复我目前拥有的代码?

4

1 回答 1

1

您必须检查滑块是否在视口中。

$(window).scroll(function() {
  var windowPosition = $(window).scrollTop();
  var slidePosition = $("#your-slide").offset().top;

  if (slidePosition < windowPosition) {
    // add code here to play slider
  }
}
于 2014-08-17T13:52:46.230 回答