重置 运行 once 函数
Reset a run once function
我正在使用 facebook 像素代码来确定用户何时阅读了整篇文章。我有一个无限博客,所以 URL 随着用户向下滚动页面而改变。当用户到达页面末尾时,我目前有一个 运行 的功能,但我需要修改它,因此如果 URL 更改,该功能将被重置,并且可以再次 运行 。这是我当前的代码。
// determine the position of element
jQuery.fn.isInViewport = function() {
var elementTop = jQuery(this).offset().top;
var elementBottom = elementTop + jQuery(this).outerHeight();
var viewportTop = jQuery(window).scrollTop();
var viewportBottom = viewportTop + jQuery(window).height();
return elementBottom > viewportTop && elementTop < viewportBottom;
};
// grab the current URL
var originalURL = window.location.href;
// check to see if element is in viewport
jQuery(window).on('resize scroll', function() {
var currentURL = '';
jQuery('.end-of-content-icon').each(function() {
if (jQuery(this).isInViewport()) {
currentURL = window.location.href;
if(originalURL !== currentURL) {
canOnlyFireOnce();
originalURL = currentURL;
}
}
});
});
// function to only fire once (courtesy of David Walsh)
function once(fn, context) {
var result;
return function() {
if(fn) {
result = fn.apply(context || this, arguments);
fn = null;
}
return result;
};
}
// Usage
var canOnlyFireOnce = once(function() {
fbq('track', 'Lead');
});
用不同的函数解决了。我传递永久链接并将其添加到数组中。如果数组中不存在永久链接,则变量 'triggerOnce' 将重置为 true 并且函数运行。
var triggerOnce = true;
var permalinkArray = [];
function callFaceBookPixel(permalink){
if(permalinkArray.indexOf(permalink) === -1) {
permalinkArray.push(permalink);
triggerOnce = true;
}
if(triggerOnce){
triggerOnce = false;
fbq('track', 'Lead');
}
}
我正在使用 facebook 像素代码来确定用户何时阅读了整篇文章。我有一个无限博客,所以 URL 随着用户向下滚动页面而改变。当用户到达页面末尾时,我目前有一个 运行 的功能,但我需要修改它,因此如果 URL 更改,该功能将被重置,并且可以再次 运行 。这是我当前的代码。
// determine the position of element
jQuery.fn.isInViewport = function() {
var elementTop = jQuery(this).offset().top;
var elementBottom = elementTop + jQuery(this).outerHeight();
var viewportTop = jQuery(window).scrollTop();
var viewportBottom = viewportTop + jQuery(window).height();
return elementBottom > viewportTop && elementTop < viewportBottom;
};
// grab the current URL
var originalURL = window.location.href;
// check to see if element is in viewport
jQuery(window).on('resize scroll', function() {
var currentURL = '';
jQuery('.end-of-content-icon').each(function() {
if (jQuery(this).isInViewport()) {
currentURL = window.location.href;
if(originalURL !== currentURL) {
canOnlyFireOnce();
originalURL = currentURL;
}
}
});
});
// function to only fire once (courtesy of David Walsh)
function once(fn, context) {
var result;
return function() {
if(fn) {
result = fn.apply(context || this, arguments);
fn = null;
}
return result;
};
}
// Usage
var canOnlyFireOnce = once(function() {
fbq('track', 'Lead');
});
用不同的函数解决了。我传递永久链接并将其添加到数组中。如果数组中不存在永久链接,则变量 'triggerOnce' 将重置为 true 并且函数运行。
var triggerOnce = true;
var permalinkArray = [];
function callFaceBookPixel(permalink){
if(permalinkArray.indexOf(permalink) === -1) {
permalinkArray.push(permalink);
triggerOnce = true;
}
if(triggerOnce){
triggerOnce = false;
fbq('track', 'Lead');
}
}