[英]Enable scrolling event when div is in viewport only once then reset when out of viewport
我試圖跟蹤每次以Amplitude進入視口的元素。 現在,當元素滾動到視圖中時,jQuery會檢測元素ID(如果元素是向上滾動還是向下滾動),並指出它是滾動事件。 這些項目顯示在振幅管理中。 問題是,當div在視口中時,每次鼠標滾動都會觸發滾動事件。 因此,當視口中每個元素僅需要一個事件時,它將創建大量事件。 如何僅觸發一次事件,然后再次將其重置為不在視口中?
function isScrolledIntoView(elem) {
// set offset by 10%
var offSet = jQuery(window).height()*0.1;
// offset scrolltop
var docViewTop = jQuery(window).scrollTop() + offSet;
// set window height area to 80%
var windowSize = jQuery(window).height()*0.8;
var docViewBottom = docViewTop + windowSize;
var elemTop = jQuery(elem).offset().top;
var elemBottom = elemTop + jQuery(elem).height();
return ((elemBottom <= docViewBottom) && (elemTop >= docViewTop));
}
var lastScrollTop = 0;
jQuery(window).scroll(function (event) {
// detects scroll direction.
var st = jQuery(this).scrollTop();
if (st > lastScrollTop){
var action = 'ScrollDown';
} else {
var action = 'ScrollUp';
}
lastScrollTop = st;
jQuery('.trackScrolling').each(function () {
// get element ID
var elementID = jQuery(this).attr("id");
var ScrollEvents = 'ScrollEvents';
// if in viewport fire event
if (isScrolledIntoView(this) === true) {
gu_event(ScrollEvents, action, elementID);
}
});
});
您需要為每個元素創建一個布爾標志,以檢查它是否已經在視口中,並添加另一個if
條件檢查它,如下所示:
var elements = [];
var lastScrollTop = 0;
jQuery('.trackScrolling').each(function () {
elements.push({
"elem": this,
"id": jQuery(this).attr("id")),
"inView": false
});
});
function isScrolledIntoView(elem) {
// set offset by 10%
var offSet = jQuery(window).height()*0.1;
// offset scrolltop
var docViewTop = jQuery(window).scrollTop() + offSet;
// set window height area to 80%
var windowSize = jQuery(window).height()*0.8;
var docViewBottom = docViewTop + windowSize;
var elemTop = jQuery(elem).offset().top;
var elemBottom = elemTop + jQuery(elem).height();
return ((elemBottom <= docViewBottom) && (elemTop >= docViewTop));
}
jQuery(window).scroll(function (event) {
var action;
// detects scroll direction.
var st = jQuery(this).scrollTop();
if (st > lastScrollTop){
action = 'ScrollDown';
} else {
action = 'ScrollUp';
}
lastScrollTop = st;
for (var i = 0; i < elements.length; i++) {
var ScrollEvents = 'ScrollEvents';
if (elements[i].inView === true && isScrolledIntoView(elements[i].elem) === true) {
// do nothing in this case...
console.log('Element ' + elements[i].id + ' is already in view!');
} else if (isScrolledIntoView(elements[i].elem) === true) {
// set the flag in this case and send the event
elements[i].inView = true;
gu_event(ScrollEvents, action, elements[i].id);
} else if (isScrolledIntoView(elements[i].elem) === false) {
// reset the flag in this case
elements[i].inView = false;
}
}
});
我沒有在scroll
功能中不斷查找所有.trackScrolling
元素,而是預先存儲了對它們的引用-每個元素的ID以及它是否在視口中都存儲在一個對象中。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.