In GTM, it's usually by replacing the var name with {{var name}}. How do I do in this Adobe launch?
I have a custom JS that's simply not reading directly from the console log. However, if I separately declare a Data Element that's a JS variable that reads from performance.timing.requestStart, I can see the value in Cloud Debugger.
How can I apply such variables here for startTime and endTime var in below code?
thanks.
function getPageLoadTime() {
if (typeof(performance) !== 'undefined' && typeof(performance.timing) == 'object') {
var timing = performance.timing;
// fall back to less accurate milestones
var startTime = performance.timing.requestStart;
var endTime = performance.timing.loadEventEnd;
if (startTime && endTime && (startTime < endTime)) {
return (endTime - startTime);
}
}
return 'data not available';
}
Solved! Go to Solution.
You do not run your code at the time. It needs to be run at the right time of the page lifecycle.
Ideally you would want to run performance code at unload time that way you know that your page is fully loaded (unless people nevigate before the page is fully loaded...).
We do it in this way:
Hey Adil,
1) Go to data elements
2) Create a new one with core extension and data element type as custom code
3) open editor
4) Just enter the code without the requirement to put everything as function but still ending with a return statement
5) Call this data element wherever you want in Launch using the "%" sign, it will do something similar to "{{" in GTM
Hope this helps
Sanmeet
Hi Sanmeet,
I'm not a 100% clear but let's try with an example as it'll make it easier for me:
I have two separate data elements in Adobe Launch:
1. SiteSpeed: fetchStart
JS variable
This pulls the timestamp (including ms) from the browser console log: performance.timing.fetchStart
2. SiteSpeed:loadEventEnd
JS variable
This pulls the timestamp (including ms) from the browser console log: performance.timing.loadEventEnd
If I wanted to create a third data element that showed the timestamp by doing this operation:
SiteSpeed:loadEventEnd - SiteSpeed: fetchStart and return the value as an integer.
Would the third variable be a Custom JS and what would the code look like?
Thanks.
Views
Replies
Total Likes
Adil,
it will be custom JS, you will use _satellite.getVar(<name of data element>) function in your to get the value of each data element, perform your operation on it and return the final value as output of the JS data element.
Hope this helps.
Sanmeet
Hi Sanmeet,
In my Custom JS, here's what I have as the code:
return _satellite.getVar('SiteSpeed: loadEventEnd') - _satellite.getVar('SiteSpeed: fetchStart');
When I check Cloud Debugger to know if the var value got passed as an event in a rule that I setup, it shows as blank.
It would be event 56 here - which I have configured to accept numeric values instead of a counter. What could be the reason for this?
Thanks.
Views
Replies
Total Likes
An event will add up all the values that you pass to it. You wont be able to achieve the objective.
Pass the value to an eVar. You will need to do this analysis in excel
Yes, so if event 56 = sum of all the timestamp differences and event event 55 = 1 (which is actually a page load counter) and will be a constant at 1 , I could create a calculated metric in AA that adds up the sum of event 56 and divides it by the sum of event 55 to get an average of load time. I'm following this article for context: https://analyticsdemystified.com/adobe-analytics/measuring-page-load-time-with-numeric-event/
What do you think about this approach?
and why isn't event 56 showing the timestamp difference as an integer in cloud debugger?
Views
Replies
Total Likes
ok, here's how cloud debugger is reading my events after setting up the below in AA report suite settings:
event 55 = counter = page load time denominator, always 1
eventt56 = numeric = %SiteSpeed: Page Load Time%
event57 = numeric = %SiteSpeed: fetchStart%
event58 = numeric = %SiteSpeed: eventLoadEnd%
values in debugger:
event55=1
event56=-1554752941276
event57=1554752941276
event58
--
event 57 is correctly pulling value for performance.timing.fetchStart from the console
event 58 is supposed to pull performance.timing.eventLoadEnd but is coming out as blank, leading to event 56 getting a negative value
event 56 is a Custom code as a data element:
return _satellite.getVar('SiteSpeed: loadEventEnd') - _satellite.getVar('SiteSpeed: fetchStart');
If I made the change in AA report suite settings for event58 as numeric type an hour ago, should it immediately show in Cloud Debugger when I reload the page?
What else could be wrong here.
Views
Replies
Total Likes
You do not run your code at the time. It needs to be run at the right time of the page lifecycle.
Ideally you would want to run performance code at unload time that way you know that your page is fully loaded (unless people nevigate before the page is fully loaded...).
We do it in this way:
What Alexis has suggested is correct. The only downside is you wont get data for the exit pages
I am not exactly sure about your code to execute this. I can suggest best practices, but providing a granular solution will be difficult
Hi Alexis,
If I had to configure the below in Adobe Launch, how would I go about with this?
In Rules section, I can't find an event for unload.
How can this be done via Adobe Launch?
Should all of the above steps happen in the same Rule? Wait for unload, save to cookies and then set variables > Send beacon ?
Thanks
Views
Replies
Total Likes
Views
Replies
Total Likes
Views
Likes
Replies
Views
Likes
Replies