Я использую 2 скрипта, которые зависят от функции $ (window).scroll. Один из них - imagescroll.js для изображений с параллаксом, а один - inview.js для анимации css3, в то время как элемент находится в видовом экране. Оба сценария выглядят следующим образом
Inview.js
$(function() {
var $blocks = $('.animBlock.notViewed');
var $window = $(document);
$window.on('scroll', function(e){
$blocks.each(function(i,elem){
if($(this).hasClass('viewed'))
return;
isScrolledIntoView($(this));
});
});
});
function isScrolledIntoView(elem) {
var docViewTop = $(window).scrollTop();
var docViewBottom = docViewTop + $(window).height();
var elemOffset = 0;
if(elem.data('offset') != undefined) {
elemOffset = elem.data('offset');
}
var elemTop = $(elem).offset().top;
var elemBottom = elemTop + $(elem).height();
if(elemOffset != 0) { // custom offset is updated based on scrolling direction
if(docViewTop - elemTop >= 0) {
// scrolling up from bottom
elemTop = $(elem).offset().top + elemOffset;
} else {
// scrolling down from top
elemBottom = elemTop + $(elem).height() - elemOffset
}
}
if((elemBottom <= docViewBottom) && (elemTop >= docViewTop)) {
// once an element is visible exchange the classes
$(elem).removeClass('notViewed').addClass('viewed');
var animElemsLeft = $('.animBlock.notViewed').length;
if(animElemsLeft == 0){
// with no animated elements left debind the scroll event
$(window).off('scroll');
}
}
}
Сценарий параллакса из следующей ссылки
Теперь проблема заключается в том, что, поскольку оба этих сценария используют $ (window).scroll, параллакс перестает работать, и вместо изображения появляется пробел. Вы можете увидеть рабочий HTML по следующей ссылке
Пожалуйста, дайте мне знать, как я могу это преодолеть.
Заранее спасибо!
Используйте пространства имен jQuery в обоих сценариях:
$window.on('scroll.imagescroll', function(e){
// CODE
$(window).off('scroll.imagescroll');
// CODE
$(window).off('scroll');