Skip to content

Instantly share code, notes, and snippets.

@mbaersch
Last active August 2, 2018 05:49
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mbaersch/a7a069a0789b02abeac898a8f0395dc4 to your computer and use it in GitHub Desktop.
Save mbaersch/a7a069a0789b02abeac898a8f0395dc4 to your computer and use it in GitHub Desktop.
SERP Bounce Tracker: Custom HTML Tag
<script>
(function() {
if (window.history) {
var s = document.location.search;
var h = document.location.hash;
var e = {{Event}};
var n = {{New History Fragment}};
var o = {{Old History Fragment}};
if (e === 'gtm.js' &&
document.referrer.indexOf('www.google.') > -1 &&
s.indexOf('gclid') === -1 &&
s.indexOf('utm_') === -1 &&
h != '#gref') {
window.oldFragment = false;
window.history.pushState(null,null,'#gref');
dataLayer.push({'event' : 'enterFromSerp', 'serpTrckEvent': 'enter'});
var tm = new Date().getTime();
document.cookie = "srp_enter="+tm+"; path=/";
//console.log("enter from serp");
}
else if (e === 'gtm.js' &&
h === '#gref') {
window.oldFragment = true;
}
if (e === 'gtm.historyChange' &&
n === '' &&
o === 'gref' &&
document.referrer.indexOf('www.google.') > -1 &&
s.indexOf('gclid') === -1) {
var tEnd = new Date().getTime();
var tPage = tEnd - {{dlGtmStart}};
var tEnter = Number({{cSrpEnter}});
var tSession = tEnter ? tEnd - tEnter : tPage;
if (tPage < 1800000) {
//console.log("back to serp after: "+tSession+' ('+tPage+')');
dataLayer.push({
'event' : 'returnToSerp',
'timeToSerp' : tSession,
'timeToSerpPage' : tPage,
'serpTrckEvent': 'exit',
'eventCallback' : function() {
window.history.go(-1);
}
});
}
}
}
})();
</script>
@mbaersch
Copy link
Author

mbaersch commented Jun 30, 2018

Code des Custom HTML Tags für die Messung von Absprüngen und Verweildauer aus Sicht der Google SERPs. Details dazu siehe Beitrag "Absprungrate und Verweildauer aus Sicht der Google SERPs in Analytics messen" im Blog.

Begleitend dazu gibt es auch den Vortrag auf der CAMPIXX 2018.

@mbaersch
Copy link
Author

mbaersch commented Aug 2, 2018

Zu Debuggingzwecken wird die Zeit auf der letzten Seite als "timeToSerpPage" auch in den dataLayer geschrieben, um den Unterschied zwischen der Messung der "Seitenverweildauer" aus dem Original von Simo Ahava und "Sitzungsdauer" zu betrachten und ggf. auch separat zu vermessen. Die auskommentierten Einträge in die Console können diese Unterschiede im Testbetrieb sichtbar machen.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment