Website speed directly impacts user experience, bounce rates, and even your search engine rankings. While Universal Analytics had dedicated site speed reports, GA4 takes a more flexible yet complex approach, requiring custom configurations to track specific metrics like page load time.
If you’re looking to understand how your subsites are performing in terms of speed, you’ll need to roll up your sleeves and configure some custom tracking. Fortunately, with GA4 and GTM, you can create a powerful setup to measure and analyze your subsites’ speed effortlessly. Find out how to do it.
Tracking Page Load Speed in GA4 Using Google Tag Manager
Step 1: Create a Custom JavaScript Variable in GTM
To track page load times, the first step is to create a JavaScript variable in GTM that calculates the time taken for a page to load:
1. Go to the Variables section in GTM and click on New.
data:image/s3,"s3://crabby-images/f8822/f8822e5b25f7863b1de19d65a2089301f00f2a64" alt=""
2. Choose Custom JavaScript as the variable type.
data:image/s3,"s3://crabby-images/cdb1a/cdb1acbe9734b29f3a3efc4bc98a35acd93c0bf8" alt=""
3. After choosing the type, we have to put in custom JavaScript code that will calculate the loading time of our pages.
data:image/s3,"s3://crabby-images/66eff/66eff65c2f46cccaa6ad403ba2c32219603a342e" alt=""
Use the following code:
function() {
if (window.performance && window.performance.getEntriesByType) {
var entries = window.performance.getEntriesByType("navigation");
if (entries.length > 0) {
var navTiming = entries[0];
var pageLoadTime = navTiming.loadEventEnd - navTiming.startTime;
return Math.round(((pageLoadTime / 1000) + Number.EPSILON) * 100) / 100;
}
}
return 0; // Return 0 if performance data is unavailable
}
Note: If you prefer to report in milliseconds instead of seconds, you can make adjustments to the JavaScript code.
4. Under the code field, open the Format Value dropdown. Turn on the option for Convert undefined to, and enter 0 as the value.
data:image/s3,"s3://crabby-images/0d151/0d151ff07f76138884e52893e0e6b5b9b60bb960" alt=""
5. Give the variable a name and save it.
Step 2: Create Triggers for Accurate Data Collection
Once you’ve created the variable, you’ll need triggers to ensure it fires correctly:
1. Go to the Triggers section and click on the New button for creating a trigger.
data:image/s3,"s3://crabby-images/feeac/feeacb0b00d731e862e1460d4ce82bf92d801dd6" alt=""
2. Select Window Loaded as the trigger type.
data:image/s3,"s3://crabby-images/d23e4/d23e4d15c5d4b0370ebf7786e1ef40226bf877d9" alt=""
3. Keep the trigger set to All Window Loaded Events and save it. This will ensure the tag fires only after the page has fully loaded in the browser.
data:image/s3,"s3://crabby-images/0ebf3/0ebf332f516a9588de043ccd51cffc923373e935" alt=""
4. Next, create another trigger for cases where the page load time is less than 0. For this, select Custom Event as the trigger type.
data:image/s3,"s3://crabby-images/728b1/728b1af6224b6c1a06fb0645341dddc24e208918" alt=""
5. Put .* as the event name and click the checkmark for using regex matching.
data:image/s3,"s3://crabby-images/25f56/25f5616e5bba2e8723acfb0c66fb642af2f3b1e3" alt=""
6. Then, select the option for Some Custom Events to define when the trigger should fire, and choose the JavaScript variable we created – Page Load Time.
data:image/s3,"s3://crabby-images/0c9df/0c9dfec4cc8df1105abde37f541e90a5dc735c92" alt=""
Enter the value that is less than 0. It will prevent our tag from firing if our variable returns 0 value. Name and save the trigger.
7. Let’s make things easier by creating a reusable variable to include this parameter in all tags automatically. Just go to Variables, click on New, and pick the Google Tag: Event Settings option.
data:image/s3,"s3://crabby-images/a3668/a3668fc319e3bc30f5b1c2e22974ef77bf3a0c8d" alt=""
8. Add Event Parameter loading_time_sec and choose our new variable as a value.
data:image/s3,"s3://crabby-images/8fea0/8fea031af60becced02ef7cdd168c7d756778507" alt=""
9. Name and save the created variable.
Step 3: Configure the GA4 Event Tag
The next step is to configure a GA4 event tag that tracks and sends page load times to Google Analytics.
1. Let’s navigate to Tags, and click New.
data:image/s3,"s3://crabby-images/cd939/cd9392cdfffc00379486a2ce51d5f81b91831623" alt=""
2. We assume that you have installed the GA4 measurement ID. Next, set the event name to page_load_time, go to Event Parameters, and include the reusable Event Settings variable we created earlier.
data:image/s3,"s3://crabby-images/63bc4/63bc46d0285f61c534b4e71c9b7f6134cc986215" alt=""
By clicking on Show inherited parameters, you can check whether created event parameters are connected.
3. The last step is to link the triggers to the tag by adding the Page Loaded trigger.
data:image/s3,"s3://crabby-images/92d7c/92d7c9b636c11141f04680ada6604ef9d70080bd" alt=""
4. Then under Exceptions, we need to add our other trigger. Let’s select the Page Load Time Less Than 0 trigger.
data:image/s3,"s3://crabby-images/0030b/0030b48560f5f24c4d204d326cf00edfe25c1739" alt=""
This ensures the tag won’t fire if the page load time variable is less than zero.
5. Now, save the tag and proceed to debug it.
6. Click preview, enter your site URL, and navigate the site. Go back to Tag Manager and we can see that the Tag is fired.
data:image/s3,"s3://crabby-images/8cad8/8cad8ad86f4e6376865881b856a80d6b41e7cd73" alt=""
7. By clicking on Variables details, we should see the raw with Page Load Time value.
data:image/s3,"s3://crabby-images/bd2d1/bd2d19a6187ac3e2fe6a385a09d86ea43d4ada3c" alt=""
8. When you're confident everything is working as it should, go ahead and publish the changes.
Viewing Page Load Time in Google Analytics 4 Reports
Now that the page load time data is being sent to Google Analytics, we need to take an additional step to make it visible in the reports. Simply sending the data isn’t enough; we also need to register the loading_time_sec parameter in GA4.
To display page load time in your reports, you’ll need to configure it as a custom metric within GA4 settings. Here’s how:
1. Log into your GA4 account.
2. Navigate to Admin in the left-hand menu.
3. Select Custom Definitions.
4. Click on Create Custom Metrics to register the parameter.
data:image/s3,"s3://crabby-images/8d062/8d062d4147c674da5d9e69d78a4cec42da42ef45" alt=""
5. Give the metric the name 'Page Load Time,' select the event parameter we configured in GTM – loading_time_sec, and set the unit of measurement to Seconds.
data:image/s3,"s3://crabby-images/0431b/0431bbdadcb5e689242d2e69dcec5ce4dbde6a0d" alt=""
6. Save the custom metric settings, and you’ll now be able to include the metric in your reports.
Creating Page Load Time Reports in Google Analytics 4
The next step is to analyze the performance of your pages by generating a report. To begin, create an Exploration report in GA4. Start by heading to the Explore section and selecting a blank report template.
From there, add the dimensions and metrics you want to include in the report. Import them into your dashboard for use. For this example, we’ll use Page Path + Query String as the dimension, along with Views and the custom Page Load Time metric we created earlier.
data:image/s3,"s3://crabby-images/ba2ae/ba2ae135758cd549ccb38208c14917d8d701d97a" alt=""
By double-clicking, you can add the dimensions and metrics as rows and values. Now, let's construct the report to display the loading times for the pages on our website.
data:image/s3,"s3://crabby-images/87f85/87f85399123edfa522d87c90e094baaae82aa4fc" alt=""
In this case, we will see the total page load time.
By following these steps, you can effectively monitor and analyze the speed of your subsites in GA4, enabling you to make data-driven decisions to enhance performance and user satisfaction.