Last Modified on January 7, 2025
Having form tracking set up on all your website forms is an absolute must. And Google Analytics 4 and Google Tag Manager make doing it easy and flexible.
In this post, we are going to explore three techniques to track form submissions with the help of Google Tag Manager and Google Analytics.
Sign up to the FREE GTM for Beginners Course...
We added one that is completely automatic as a bonus. Despite being the easiest to do, we’ll explain why it may not be the best solution.
Here is an overview of what we’ll cover:
- What Should You Track?
- How to Track Form Submissions
- Which Technique Should You Use?
- Tracking Form Submits with a URL Success Page
- Testing
- Form Tracking with a Form Submit Trigger
- Form Tracking with an Element Visibility Trigger
- Other Form Tracking Techniques
- FAQ
🚨 Note: In this post, we’ll demonstrate the repetitive process of creating a new tag or trigger once in the first example. Afterward, we’ll show how to set up other form-tracking methods without these detailed explanations. For tags, triggers, and conversions, refer to this section. To test your setup, refer to this section.
What Should You Track?
Here are the things you can track in your forms:
- Form submissions
- Pulling data from form fields
- Inserting information from your website into form fields
- Prefilling form fields
In this post, I’ll be talking about form submission tracking specifically. However, here are some of our other guides on form tracking:
- How to Capture UTM Parameters in Form Fields
- Form Field Tracking with Google Tag Manager
- Form Tracking with Contact Form 7
- How to Prefill Forms with GTM
How to Track Form Submissions
You can track form submissions using any of the following three methods:
- Unique URL Trigger
- Form Submit Trigger
- Element Visibility Trigger
Why are there three different techniques? Well, there are always multiple techniques to get the data you want. You shouldn’t be discouraged when one doesn’t work for what you need.
If you are flexible, you can learn about the capabilities of each. This way, you’ll be able to implement and test different tracking techniques so you get the data that you need in your system.
This holds especially true for forms because there are many shapes and sizes of forms available, each with different technologies.
Sometimes, the trigger or the technique I show in my tutorials won’t work for your specific form, so it helps if you stay flexible and know about these different tracking techniques.
In this post, I’ll show you different form tracking techniques, one that doesn’t include GTM and three others with GTM that I use the most often.
Which Technique Should You Use? (Test Your Form)
Start by having your web page with the form you want to track, Google Tag Manager, and GA4 open in three separate tabs. In our demo shop, we have several different contact forms.
This tutorial covers different form tracking techniques, but not all work with all types of forms. To find out which tracking technique we need to use, you’ll first need to test your form.
This will help you determine what successful outcome we should use as our form trigger and which technique to use. There are three that we will focus on in this tutorial: a URL success page, a form submit trigger, and an element visibility trigger.
Before we start, in your form, fill out some test information. Click on Send and see what happens.
In the case of this first form case, we get redirected to a success page with a unique URL in the address bar.
Keep track of these interactions on your site. If there is a clear success page here and the URL changes, you can track form submissions using ordinary pageviews on Google Analytics without much extra effort.
You should use the first form tracking method of this tutorial: Tracking Form Submits with a URL Success Page.
Let’s demonstrate a different potential outcome. If your contact form doesn’t lead to a new URL when a user submits, tracking can get a little more tricky.
In this second contact form, we seem to be redirected to a success page, but the URL doesn’t change. Instead, we get a message on the same page that this was submitted successfully.
If this is how your contract form behaves, we need to try a different tracking approach because there’s no new page view to track. In this case, you should use the second method in this tutorial: Form Tracking with a Form Submit Trigger.
For the third possible contact form, we can see a success message at the bottom of the form, which is still visible. There is no new URL, and besides the addition of this text element, the page hasn’t changed after submitting the form.
If your form submission looks like this, you might have a couple of options. You can’t track success based on the URL, but you might be able to use the Google Tag Manager forms submission from the second method.
This is especially handy if you already have this form trigger set up.
In some cases, you might not want to use the form submit trigger if it has some problem or if you don’t even see the event inside of Google Tag Manager.
In this case, you’ll want to try the third method covered in this post: Form Tracking with an Element Visibility Trigger.
So, let’s dive in!
Method #1: Tracking Form Submits with a URL Success Page
Steps summarized:
- Determine the URL users land on after a successful form submission.
- In GTM, go to Triggers → New.
- Select Page View trigger type and configure it to fire on the success page URL.
- Save the trigger.
- In GTM, go to Tags → New.
- Select your desired tag type (e.g., Google Analytics: Universal Analytics).
- Set up the tag with appropriate tracking parameters.
- Attach the previously created page view trigger.
- Save and publish the tag.
If you’ve got Google Analytics deployed, you can quickly get some data for the success page in your GA4 account in two ways.
Either use the DebugView or head to the Realtime report (especially useful if DebugView is delayed or not showing any data).
For the DebugView, click on the incoming Pageview event and then click the page_location parameter to see the page URL.
In the Realtime report, you can check the page title that appears in the Views by Page title and screen name card and check when the success page title appears there (It may take just a few seconds before it shows up in the list).
In the same report, you can also look at the Event count by Event name card. In the card, click page_view, then page_location (you may have to click on the succeeding page navigation to show more parameters).
Then, hover over the list of URLs to find the right one.
From here, you can classify this as a Google Analytics 4 Conversion Tracking (i.e., Goals in UA) so that every time somebody goes to this page, there will be a conversion within Google Analytics.
Create a Conversion in Google Analytics
We will cover two simple methods to track Pageviews conversions in GA4: one using the GA4 interface and the other with Google Tag Manager.
Which one should you go for?
In simple terms, if you’re already using GTM for most of your setup, it’s likely better to stick with it. Keeping everything in one place makes it easier to stay organized and keep an eye on your tracking setups.
Pageview Conversions with Tag Manager
In the left navigation, click Tags, then click New.
Then, click Tag Configuration → Google Analytics → Google Analytic: GA4 Event. Model our example with your data. We used a constant variable for the Measurement ID, but you can also paste your GA4 Measurement ID.
The Event name is page_view_thankyou. Click Save.
Now, set up a trigger to decide when the tag should fire. To create a tag, click the Triggering section under the Tag Configuration section.
In Choose a trigger, click the plus sign +.
Click the Trigger Configuration section and select Page View.
Select Some Page Views. You can model our trigger below:
We use the following condition: Page URL contains https://demoshop.measure.school/contact-us/thank-you-page/
Click Save. After testing (refer to the Testing section in this post), publish your container.
Pageview Conversion in GA4 Interface
In GA4, click Admin → Data display → Events. Then, click the Create event button.
You’ll have to click the Create button.
You can now configure your event. Here is an example of how you can track your thank-you page as a conversion.
In the Configuration section, enter your new event name in the Custom event name field. Feel free to choose any name, but make it descriptive and adhere to GA4 event naming conventions.
Avoid using generic names like page_view since you’re already tracking pageviews in your system. Also, page_view is a reserved name by Analytics. You’ll see a dropdown list of such events as you click on the field.
Therefore, instead of page_view, consider using something more specific like page_view_thankyou (please use a better name).
For Matching conditions, you may wonder why you need to write another event name since we already created one or why use this as a parameter.
The Matching conditions set the conditions for when you want your custom event to happen. Also, you need to use other events and parameters that already exist to create your event.
So you’ll have to tell Analytics what needs to match for your event to be registered.
For the first parameter:
- type or select event_name
- select equals as the Operator
- type page_view for the value (because this is the existing event name we’re deriving for our custom event)
For the second parameter:
- type or select the existing parameter page_location
- select contains as the Operator
- copy your thank-you page URL in the value field. Ours is https://demoshop.measure.school/contact-us/thank-you-page/
Click Create.
🚨 Note: Your event is now created but must be marked as conversion. Once your event is created, you can either wait for 24 hours to see it in your list of events and mark it as a conversion, or you can start using it as a conversion right away.
To instruct Analytics to mark your event as a conversion, go to Admin → Data display → Conversions.
Click the New Conversion Event button.
In the New Event Name field, enter the name you used for the event you created in the previous steps. Click Save.
Your event is now marked as a conversion and will show in your list of Conversion Events.
Testing
To test your event, fill out and submit your form. Afterward, confirm that your tag works correctly in both GTM and GA4.
In GTM, click the Tags header to check if your tag was fired. Select the event associated with your tag in the left Debug panel. If the tag didn’t fire, investigate why your setup isn’t working.
Now that we know everything is working in GTM, we must ensure that GA4 receives the data.
Check the DebugView in your GA4 account and look for your event. You’ll know it’s a conversion if the green flag icon is attached to your event. You can also look at your Realtime report, as we’ve shown earlier.
Alternatively, look at the Realtime report if you experience issues in DebugView.
Method #2: Form Tracking with a Form Submit Trigger
Steps summarized:
- In GTM, go to Triggers → New.
- Select Form Submission trigger type and configure it to track all forms or specific forms.
- Save the trigger.
- In GTM, go to Tags → New.
- Select your desired tag type (e.g., Google Analytics: Universal Analytics).
- Set up the tag with appropriate tracking parameters.
- Attach the previously created form submission trigger.
- Save and publish the tag.
Set Up in Google Tag Manager
If your contact form changes appearance and presents a success message without navigating to a new page with a different URL, you’ll need to build something in Google Tag Manager to make this work.
One of the methods is to use the built-in form submission trigger to pick up the interaction of submitting the form.
Create Form Submit Trigger
Follow the same steps to create a trigger, as shown in the Pageview Conversions with Tag Manager section of this post. Then, follow this configuration:
Set Up Form Variables
Before testing and previewing your changes, make sure to enable your Form variables so they can capture form interaction data.
Click Variables in the left navigation panel, click Configure at the top right corner, and activate your form variables:
Enable the preview and debug mode and test your form.
🚨 Note: When you’re about to submit your form, I suggest you use these shortcuts, either by holding Command (⌘) for Mac or Control (Ctrl) for Windows while clicking the Send button. This opens the success page in a new tab, leaving your form tab untouched, making it convenient for inspecting form submission tracking in Google Tag Manager.
Inspect Form Submit Variable Fields
To inspect your trigger tracking, click the Variables header in your Google Tag Manager box.
Here’s where you can find the variables that you just activated. You can inspect them and see how they get filled when you complete an action like submitting the form.
This is what Google Tag Manager picks up from the form, and you can use that information to build a trigger and fire a tag.
Now, it’s important to remember that this trigger should be unique to this specific form so that your GTM form submission doesn’t trigger when another form, like a search form, is filled out.
To demonstrate, test a different form and observe unique form variable values.
A best practice is to use a Form ID. If a Form ID is available, Google Tag Manager picks it up and includes it in form variables. In our example, it is gform_7.
Use these variables to refine your trigger for this event. In Google Tag Manager, edit the form trigger to fire on your contact form.
Here’s an example of a trigger.
Now, you can test your configuration and create your goal as we did in the Test and Create a Conversion section.
Top Tip: Wait for Tags and Check Validation
You might have seen these options that I’ve skipped in the trigger section: Wait for Tags and Check Validation.
My experience with these checkboxes is that you need to test them before implementing them and not just tick them by default. So, if your form now works and your conversion is tracked, I recommend trying these out.
1. Check Validation:
If you check the box for Check Validation, you will get more fields. Here, you can use your Page Path variable or page URL variable to tell Google Tag Manager when it should track this form submission.
For example, maybe you don’t want to pay attention to all the pages.
If you only want to track this on the Contact Us page, you can specify that by selecting Page Path, contains, and the URL segment for your page. This will turn on the Check Validation feature for this form.
This means that if a user has entered something wrong, such as an invalid email address, you usually get an error, so you don’t want to fire your tags.
This function prevents this from happening, but it doesn’t always work for every form, depending on how it is built.
Therefore, I would test this with your form rather than turn it on by default. If this solves your problem, keep it checked. If it breaks your trigger and suddenly you don’t get your form submission anymore, I would turn this off.
2. Wait for Tags:
I recommend you test the Wait for Tags option before implementing it rather than check it by default. Wait for Tags is a function that ensures your event and all your tags have been fired before the user gets redirected to the next page.
Usually, I think this is a good option to take. But again, because this won’t work well for all forms, I would thoroughly test this before deploying it.
Method #3: Form Tracking with an Element Visibility Trigger
Steps summarized:
- Determine the thank you message or confirmation element that appears after form submission.
- In GTM, go to Triggers → New.
- Select Element Visibility trigger type.
- Configure the trigger to detect the visibility of the confirmation element.
- Save the trigger.
- In GTM, go to Tags → New.
- Select your desired tag type (e.g., Google Analytics: Universal Analytics).
- Set up the tag with appropriate tracking parameters.
- Attach the previously created element visibility trigger.
- Save and publish the tag.
What is the Element Visibility Trigger?
If your form adds a new element to the page upon submission, then using an element visibility trigger is a good way to track form submissions.
Element visibility triggers fire when a page element becomes visible on a user’s screen, which is helpful when a pageview doesn’t necessarily demonstrate user engagement.
This can be useful for things like scroll tracking, but in our case, we want to use an element visibility trigger to track an element that only becomes visible after a form has been submitted.
Let’s look at this in Google Tag Manager and create a new trigger as in previous sections here.
Select Element visibility.
What is this trigger all about?
As its name implies, the element visibility trigger will fire if something is visible on the screen to the user. It does this by inspecting and observing the document object model (DOM) to see if there are any changes.
Inspect Your Page with Chrome Developer Tools
Right-click on the success message of your form, and go into our developer tools by clicking on Inspect.
What you see is the representation of the DOM. Here, we can choose one of the elements that is changing during the page load.
We can see that there is a div class called wpcf7-mail-sent-ok, which is one of the nodes that gets inserted when a submission has happened successfully. Copy this node.
🚨 Note: The class in this node will change if you reload your page. That is because the wpcf7-mail-sent-ok only appears when a form is filled and submitted. Therefore, pay attention to what you copy.
Set Up in Google Tag Manager
Create Element Visibility Trigger
An effective element visibility trigger needs a tag that fires when the element changes. It helps to have CSS knowledge because we will use it to tell GTM which element to observe.
If you don’t know CSS, follow along closely, and you should still be able to create the trigger. In the trigger configuration on Google Tag Manager, you are given the option to use either the ID or the CSS selector.
Since the div node we found earlier doesn’t have an ID, you will need to use the CSS selector.
Element Selector
What do you enter into the CSS selector field? This is something we can test in our JavaScript console.
To access the console, select the Console header in your developer tool. In the command field at the bottom of the console, type document.querySelector followed by parentheses around a pair of double quotes.
Between the quotes, you can enter any CSS selector and try this out. Now, in this case, we have a div node, so we can look for the CSS by typing div in the quotes.
Therefore, the whole text in the command field should read document.querySelector(“div”).
To test this, hit the enter key. You’ll get the first div that’s on the page. Here, that was the div class hfeed site.
As it turns out, that’s not the div that we wanted to select. We wanted to select the one that changed earlier when we submitted the form: the class wpcf7-mail-sent-ok.
Use the dot notation to select a specific class. This time, add a dot and then the class that you want. Your command field should read document.querySelector(“div.wpcf7-mail-sent-ok”).
Press enter, and then hover your mouse over it. The success element on your form page should light up in response when you do, which tells you that you have found the element that you want GTM to observe.
You have confirmed that this is the correct CSS selector to enter into your GTM trigger configuration. Copy the whole node div.wpcf7-mail-sent-ok.
When to Fire This Trigger
There are a few options for trigger frequency. For this particular form, users can fill it out and submit it multiple times without navigating away from the page. Because of this, you should select the option Every time the element appears on the screen.
Visibility
The visibility field asks how much of the element needs to be visible for the trigger to fire. If it’s at the edge of the screen, it’s not visible to the user, but you still want to trigger the tag. 50% is fine in that case.
Observe DOM Changes
You’ll also need to select the Observe DOM changes option. A little warning box will appear because it can slightly affect site performance, but realistically, it shouldn’t affect too much of the page load time.
🚨 Note: Check out our handy guide and learn to track page load time with GA4.
Trigger on All Elements
For the last option, select the All Visibility Events button.
Remember to give your trigger an appropriate name that will make sense when you look at your tags later. Save and refresh the page.
Testing
To test your new trigger, refresh Google Tag Manager, refresh your form page, and close the developer tools box. Then, follow the testing steps shown in the Testing section.
Fill out and submit your form one more time. Once you’ve submitted it, you’ll see your element visibility tag appear in Google Tag Manager. That’s it!
Other Form Tracking Techniques Worth Mentioning
- Form Tracking With AJAX – explained in MeasureMasters
- History Change Listener – explained in MeasureMasters
- Data Layer Pushes – explained in MeasureMasters
Summary
So there you have it! This is how you can track forms with the help of Google Tag Manager and Google Analytics. These are three main forms of tracking techniques and should cover most use cases.
If you want to pull more contextual data from user actions that you’re tracking in GTM, that’s where the relative click variable comes in handy.
Form tracking is also available in GA4. You can learn more about it in our handy guide on automatic form tracking in GA4.
Are you using ninja forms for your website? Learn how to track ninja forms with GA4 and GTM!
Have you enjoyed success with a different technique? Would you like to see more content on other tracking techniques? Please leave a comment down below!
FAQ
How can you track form submissions using a URL success page?
If your form leads to a success page with a unique URL, you can track form submissions using ordinary pageviews on Google Analytics.
You can create a Conversion in GA4 and set it to trigger whenever someone reaches the success page URL. The other option is to track it automatically using the Form interactions in Enhanced Measurement.
Can you track form submissions with Google Analytics without using Google Tag Manager?
Yes. If you already have Google Analytics deployed, you can track form submissions directly through Google Analytics by creating Conversions or enabling the Form interactions feature in Enhanced Measurement.
However, using Google Tag Manager provides more flexibility and control over tracking and allows for additional customization options.
How can you test the form tracking techniques?
To test the form tracking techniques, you need to fill out and submit the form on your website.
Depending on the outcome (success page with a unique URL, success message without URL change, or visible confirmation message), you can determine which technique to use for tracking form submissions.
Thank you for the video! It helped a lot!
Hi Julian, great video.
However, I see that you set up the trigger to fire every time the “thank you” element appears in the viewport. After firing it, you scrolled to the top of the page, so the element was no longer in the viewport. Don’t you think that it will fire once again when you scroll back to it? And if yes, how would you handle the option to submit the same form multiple times on the same page?
Best regards and thank you in advance.
You could add the option fire once per page in your tag settings to prevent it from firing again.
I am talking about form submissions that do not result in a page reload or redirect – when you just submit the form and a ‘thank you’ div appears on the screen. So how would you handle multiple form, submits in this case (because sometimes the users tend to do so)?
I refer to your videos and tutorials all.the.time. You are the BEST. Thank you so much for putting these out there, you’re always my first stop when looking for anything GTM.
Thanks Elise. You made my day
It is very nice to explain with visuals. Thank you so much. You’re the King!
Hi Julian, in 2) how would you prevent multiple ‘submit’ clicks because the built-in form submit trigger can’t really tell between successful and unsuccessful. This has been providing a lot of inflated form submission numbers for me on Google Ads.
actually there are 3 different methods here. So if you feel like the form submit trigger is not up to your standards, use the other method.
There are some techniques to make it more accurate (like a javascript callback), but it would take another post to explain this.
Julian,
Just wondering on the GTM Form Submission, I am trying to track all forms on the website and set up a Goal to see how many forms has been filled out? I had set up a GA and Form trigger but having some challenge to see the goals on Google Analytics. Any feedback would be helpful.
it depends on how you setup your gaol. Make sure to choose and Event goal
wpcf7-mail-sent-ok not display after update Contact Form 7 plugin. Is there any way to track?
yes, any of the other 2 ways also work
Here is my scenario. On my /contact page, I have a contact form with a landing page. This same form is used on multiple pages; i.e. on the /about-us and /order pages, there is a button that directs to the same /contact page. How do I track the submissions that are triggered only from the /order page? Is this doable?
Thanks
it depends what trigger you use. For a Pageview trigger, you might want to incorporate the Referral variable in your trigger. For a Form Submit trigger you could use the URL variable. Just add them as a condition to your Trigger and enter the URL of your /order page
This was wonderful and so helpful! Thank you.
Thank you so much this has been brilliant I was really stuck and had spent a number of hours, when of course I should have come and checked here first. Thank you for all the time and effort you put into making tutorials that are clear and practical and easy to understand.
Excellent and the best guide so far in the internet. Thank you.
Hey Julian,
I have followed all your directions to create a tag with an element visibility trigger, but I am not sure how to translate that into a goal since when the pop form is submitted there is no URL change? I had to use the CSS selector to target the thank you text that pops up for a few seconds. Hopefully this makes sense!
Hi Julian, thanks for sharing! I tried many ways to track a form submission (happyform) but everytime I tried to test, the variables are “undefined” even tough there’s a form Id, a form class etc… How can I fix this ? Thanks for your help