Set up enhanced conversions manually with the global site tag (beta)

Enhanced conversions is a feature that can improve the accuracy of your conversion measurement. It supplements your existing conversion tags by sending hashed first-party conversion data from your website in a way that safeguards privacy. The feature uses a secure one-way hashing algorithm called SHA256 on your first-party customer data, such as email addresses, before sending to Google. The hashed data are then matched with signed-in Google Accounts to attribute your campaign conversions to ad events, such as clicks or views.

You can set up enhanced conversions with minor or no changes to your tagging configuration in one of two ways: using Google Tag Manager or the global site tag.

This article will explain how you can set up enhanced conversions manually if you are currently using the global site tag and explains common issues with validation and implementation.

If you would like to implement enhanced conversions with Google Tag Manager, read Set up enhanced conversions manually with Google Tag Manager.

Before you begin

Note: Conversions measured by importing Google Analytics goals are not supported for enhanced conversions. If you'd like to use enhanced conversions, consider setting up a new Google Ads conversion action with a global site tag or Google Tag Manager.
  • Know the conversion page URL where the conversion tag fires (e.g. the confirmation page URL) and the conversion event trigger (for example, a button click or a page view).
  • Make sure that there is first-party customer data available (email, full name and home address and/or phone number) on the page where your conversion tracking tag fires.
  • This implementation requires knowledge of how conversion tracking is set up on your website and some code changes, so make sure that you are able to speak with your development team as needed.
  • Please ensure that you have reviewed and confirmed that you can comply with the enhanced conversion customer data policies in Google Ads (see steps on this below, under 'Instructions').
Note: We’ve made a series of updates to help you better understand the impact of enhanced conversion to your reporting. You can now see the impact of your enhanced conversions with new results available in your conversion action table. Learn more about the enhanced conversions impact results


  1. Sign into your Google Ads account.
  2. In the upper right corner of your account, click the tools icon Google Ads | tools [Icon] and under "Measurement", click Conversions.
  3. In the 'Enhanced conversions' section at the bottom, click Turn on enhanced conversions.
  4. Review the compliance statement. To enable enhanced conversions, you must confirm that you will comply with our policies and that the Google Ads Data Processing Terms apply to your use of enhanced conversions. Click Agree to acknowledge your acceptance of these terms.
  5. Check your website for a Google tag. Click Check URL to check your website for a Google tag.
  6. In 'Tag type', you should be defaulted to Use Global Site Tag if that is how you track conversions for this conversion action. Because you used the global site tag to set up website tags, you need to use it to set up enhanced conversions.
  7. Select the setup option that you want to use:
    • Select JavaScript or CSS Selectors: Select one or more pieces of customer information (such as email, address and/or phone) that you want to send with enhanced conversions directly in the Ads UI. Keep this tab open since you’ll be inputting details about your customer data directly on this page.
    • Edit code
      • Use an event snippet: Add a code snippet on your website that sends hashed customer data for matching.
      • Use the enhanced conversions API: Set up a direct API integration to Google to send customer data for matching. If you are interested in the enhanced conversions API option, please reach out to your Google representative.
        Note: If you send Google enhanced conversions data in a way that’s different from what you’ve already selected in Google Ads, that data may not be processed. For example, if you choose 'Select JavaScript or CSS Selectors' and try to send data directly through your enhanced conversions API, that data will not be processed.
  8. Click Save.
  9. A few days after you set up enhanced conversions, you’ll see “Recording conversions (enhanced conversions detected)” in your “Status” column. This means we are currently processing your enhanced conversion data and will notify you once it’s integrated into your conversion action.
Note: After your enhanced conversions are processed, they will show up in your reporting and your conversion “Status” column will say “Reporting (enhanced conversions)”. That means we have started using enhanced conversion data in the reporting for your conversion action. If you hover over the status, you’ll see the date we detected the adoption of enhanced conversions and the impact of reported conversions for this conversion action. We’ll tell you the campaign type and the percentage of reported conversions.

Set up enhanced conversions using JavaScript or CSS Selectors

Find enhanced conversions variables on your conversion page

  1. Using the Chrome browser in a separate tab from your Google Ads account, navigate to your conversion page. If you are unsure which page this is, you should contact your developer.

Identify any customer data that is displayed on the page that you wish to send to Google. As an example, your page may display a thank-you message and include a customer email address after a purchase.

Note: At least one of the following variables must be provided for enhanced conversions to work properly:

  • Email (preferred).
  • Full name and address (first name, last name, street address, city, region, postcode, country – all are required if you choose to use this data).
  • [Optional] A phone number can also be provided along with an email or full name and address (but not by itself).

2. Once you have identified the customer data on the page, you will need to follow the next step to copy the CSS Selectors and enter those into Google Ads so your automatic enhanced conversions know which pieces of data to hash and send to Google. It’s important that you keep this conversion page tab open.

Identify enhanced conversions CSS Selectors and input into Google Ads

First, if you haven’t already, you’ll want to open your Google Ads account to the automatic enhanced conversions page (in one tab). Here’s how to do so if you don’t have it open:

  1. Sign in to your Google Ads account.
  2. In the upper right-hand corner of your account, click the tools icon Google Ads | tools [Icon] and under 'Measurement', click Conversions.
  3. Select the conversion action that you want to measure with enhanced conversions and then expand the 'Enhanced conversions' section.
  4. Tick the box for each piece of customer data you plan to implement (for example, email, name and address, etc.).
  5. Select JavaScript or CSS Selector.
    • If you’re using JavaScript variables, it may be easiest to ask your developer which variables should be added to these fields.
    • If you’re using CSS Selectors, you can follow the steps below.

To identify the CSS Selectors to input into those fields, follow these steps:

  1. On your conversion page, when you have found the corresponding customer data you want to send with automatic enhanced conversions, use your mouse to right-click on top of it and select Inspect.
    • If you are inputting the CSS Selector for email in Google Ads, make sure that you right-click the email address displayed on your conversion page.
  2. You will see the Chrome Developer Tools launch within your Chrome browser.
  3. Within the source code presented in the Chrome Developer Tools page, you will see a portion of the code highlighted. This highlighted code is the portion that includes the CSS Selectors for the customer data you right-clicked in Step 2 of this section.
  4. Hover your mouse over the highlighted code and right-click it.
  5. Scroll down to Copy , then choose Selector.
  6. Paste that text in the Google Ads automatic enhanced conversions section (on your other tab) in the corresponding field.
    • For reference, it should look something similar to but not exactly like this:
      tsf > div:nth-child(2) > div.A8SBwf > div.RNNXgb > div > div.a4bIc > custEmail
  7. Complete steps 2-6 of this section for each different customer data type (e.g., email, name and address, etc.).
  8. In Google Ads, click Save.

Enhanced conversions is now set up. The next step is to validate that it’s working properly. Go to the 'Validate your implementation' section below.

Set up enhanced conversions by editing your website code

If you currently have conversion tracking implemented using Google’s global site tag directly on your page (not within a third-party tool or iFrame), you can implement enhanced conversions by making slight changes to your global site tag.

Before implementing, make sure that your 'Tag type' is noted as 'Global Site Tag', the implementation method is 'Edit Code' and you have chosen the 'Use event snippet' button when setting up enhanced conversions for this conversion action.

Identify and define your enhanced conversions variables

Ensure that the variables you need like email, address and phone number are available on the conversion page where the Google Ads event snippet fires. This will likely be the case on conversion pages for purchases, sign-ups and other similar conversion types that often require customer data. If you are unsure which page this is, you should contact your developer.

Once you’ve confirmed that the information is available, you’ll need to validate that the variables on this page are stored as global JavaScript variables so they can be used by the enhanced conversions snippet.

Note: At least one of the following variables must be provided:

  • Email (preferred).
  • Full name and address (first name, last name, street address, city, region, postcode, country, all required).
  • A phone number can also be provided along with an email, or full name and address.

The table below lists more information about the variables you can define. The 'Key Name' column indicates how they will be referenced in the enhanced conversions HTML snippet, which is created in the next step. Note that all data should be passed as string type variables.

Data Field Key Name Description
Email address email User email.
Phone number phone_number User phone number. The tag will remove symbols and dashes, but the number must contain the country code.
First name first_name User first name. Example: 'John'
Last name last_name User last name. Example: 'Doe'
Street address home_address.street User street address. Example: '123 Main St'
City User city name. Example: 'Melbourne'
Region home_address.region User province, state or region. Example: 'Victoria' or 'VIC'
Postcode home_address.postal_code User postcode (5-digit version only). Example: '12345'
Country User country code. Example: 'AU'. Use two-letter country codes as per the ISO 3166-1 alpha-2 standard.
Note: You’ll need to make sure that the customer data are available when the conversion tag fires. If the user information is collected on a previous page, you’ll need to make sure that it’s available in your code on the conversion page to configure it in this script.

Implement the enhanced conversions script

Configure and add the following script on your conversion page where the Google Ads event snippet is installed. Ensure that you update variable names below to match the variable names for those attributes on your webpage.

For example, if you store email in a variable named 'email_address', then the snippet should be edited to reflect that (e.g. where it says yourEmailVariable).

// Implement
var enhanced_conversion_data = {

"email": yourEmailVariable, ***Change yourEmailVariable to the actual Javascript variable name where you are storing the user’s email data. Do the same for the other variables below. Make sure that the values are not hashed.

"phone_number": yourPhoneVariable,
"first_name": yourFirstNameVariable,
"home_address": {
"street": yourStreetAddressVariable,
"region": yourRegionVariable,
"postal_code": yourPostalCodeVariable,
"country": yourCountryVariable
  • The conversion tracking tag will perform basic normalisation on the data you provide, so you shouldn’t need to re-format your data. For phone numbers, the tag will remove symbols and dashes, but the number should contain a country code so that it can be formatted into the E.164 standard.
  • If your site doesn't collect one of the above fields, remove the field entirely rather than leaving it blank. For example, a website that only collects emails and phone numbers would look like this:
// Implement
var enhanced_conversion_data = {
"email": {{ yourEmailVariable }},
"phone_number": {{ yourPhoneVariable }}

Note: At least one of the following variables must be provided:

  • Email (preferred).
  • Full name and address – for address, all data fields must be provided (first name, last name, street address, city, region, postcode, country).
  • Phone number (must be provided in conjunction with email or full name and address).

Multiple values

Developers can optionally provide multiple values (up to 3 for phone number and email and 2 for address) by using an array value rather than a string. If you capture more than 1 value, providing this will increase the likelihood of a match. See the example below:

var enhanced_conversion_data = {
"email": [yourEmailVariable1, yourEmailVariable2],
"phone_number": [yourPhoneVariable1, yourPhoneVariable2],
"address": [
{street: yourStreetAddressVariable, city: yourCityVariable, region: yourRegionVariable, postcode: yourPostcodeVariable},
yourStreet AddressVariable, city: yourCityVariable2, region: yourRegionVariable2, postcode: yourPostcodeVariable2}
Configure your conversion page global site tag
  • Add '{'allow_enhanced_conversions': true}' to the config line to your global site tag that triggers across all pages.
gtag('config', 'AW-CONVERSION_ID', { ' allow_enhanced_conversions' true } ) ;
  • Before: Example of the global site tag (currently in place):
<!-- Global site tag (gtag.js) - Google Ads: 123456 -->
<script async src=""></script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'AW-123456');
  • After:
<!-- Global site tag (gtag.js) - Google Ads: 123456 -->
<script async src=""></script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config','AW-123456', {'allow_enhanced_conversions':true});

Validate your implementation

To verify if your enhanced conversions implementation is working correctly, navigate to your conversion page (you may have to complete a test conversion to do this) and follow these steps. It’s best practice to do this immediately after implementing enhanced conversions so any changes can be made if it is not working properly.

Validate your implementation using Chrome Developer Tools

  1. Right-click on your webpage.
  2. Select Inspect.
  3. Select the 'Network' tab.
  4. Enter your conversion ID or conversion label in the search bar.
  5. Find the network request that is going to (or on some browsers).
  6. In the 'Headers' part of the network request, scroll to 'Query String Parameters'. Here, you should find that there is a parameter 'em' with a hashed string as the value. If you see the 'em' parameter, this means that the enhanced conversions tag is correctly picking up and hashing the enhanced_conversion_data object.

After 72 hours, review the Diagnostics report to confirm your implementation

About 72 hours after implementing enhanced conversions, you will be able to view the tag diagnostics report in Google Ads, which you can use to validate that your implementation is working properly. To get there

  1. Sign in to your Google Ads account.
  2. In the upper right-hand corner of your account, click the tools icon Google Ads | tools [Icon] and under 'Measurement', click Conversions.
  3. Click the conversion action that has enhanced conversions enabled.
  4. Select Diagnostics from the page menu at the top. You’ll be able to see your enhanced conversions tag diagnostics report and the metrics for your enhanced conversions in each section.
  5. Review the various health checks to make sure everything is working as expected.
  6. If the tag diagnostics report notifies you that something may be wrong, follow the instructions in the notification and the Help Centre to troubleshoot.

Common Issues

If you're unable to validate your enhanced conversions implementation, you should go back through the setup instructions to ensure that all necessary steps were followed. If you’re still having trouble, below is a list of common reasons why you may be encountering issues with your enhanced conversions implementation.

No tag detected

If you see a 'No tag detected' error when trying to initially activate enhanced conversions, you have an error in your website URL or Google tag, so:

  • Check the spelling of the URL.
  • If you do not have conversion tracking tags in place using the global site tag or Google Tag Manager, you should implement conversion tracking with one of those methods.
  • If you’ve installed a Google tag on your website, you can select one manually and indicate if it uses the global site tag or Google Tag Manager. You may need to troubleshoot your site-wide tagging to ensure that you have properly implemented conversion tracking using one of those 2 methods.

Multiple tags are detected

Choose one of the tags listed in the dialogue box. If you have a global site tag AND Google Tag Manager, choosing the global site tag is recommended.

Enhanced conversions data are not available at the time of conversion

Enhanced conversions data may not be available at the time of conversion, like when that information is collected on another domain (for example, paying through a third-party domain) or if it is collected elsewhere in the conversion flow (for example, signed-in customers may not re-enter their first-party information or it may be collected on the previous page).

Pre-hashed data are being provided in your enhanced conversions

We use the SHA256 algorithm to hash the first-party data you provide, which is the industry standard for one-way hashing of data. At this time, enhanced conversions does not support pre-hashed data.

The enhanced conversions parameter (allow_enhanced_conversions) is not configured to be true within the global site tag

If enhanced conversions is not declared in the tag configuration as true, then the implementation will not work. Review the Configure your conversion page global site tag step above for more information.

Variables were not successfully implemented for enhanced conversions

For global site tag users, make sure that you have passed the necessary first-party data into global JavaScript variables on the page where the conversion tag is firing. It may be necessary to retrieve information entered from a previous page.

Code snippet copying errors

Make sure when implementing the enhanced conversions code that it was copied correctly and then updated to reflect your variable names (and not placeholder information).
Was this helpful?
How can we improve it?

Need more help?

Sign in for additional support options to quickly solve your issue

Clear search
Close search
Google apps
Main menu
Search Help Centre