This article is a guide to setting up and using Amplitude's Tealium integration.
Tealium's two main products are an enterprise tag management service, Tealium iQ, and a real-time unified marketing platform, Tealium AudienceStream.
There are two ways customers can send data to Amplitude:
This integration is maintained by Tealium. Contact the Tealium support team with any questions about this integration.
Tealium IQ is a universal JavaScript library that creates a universal data object (UDO) for all elements of a page. This data is first sent to the data layer in Tealium, after which you can send it to third-party vendors (including Amplitude) with the tag.
There are two ways you can integrate Tealium iQ with your website: you can use Tealium's tag manager or their JavaScript library. This section discusses using Tealium iQ (tag manager) to send data to Amplitude.
To integrate Tealium with Amplitude, follow these steps:
In your Tealium workspace, create a data layer for your application. This is where you define the variables you need. (See the next section for more details.)
Next, create a project for your data on Amplitude. This generates an API key for you.
In the Tags tab in Tealium, add Amplitude. You can input the Amplitude API key in the tag configuration. You can also create load rules and data mappings here.
In Tealium, navigate to the Code Center, which can you can find in the dropdown menu in the top right-hand corner. This is where you find the JavaScript snippet to paste into your app.
In your app, paste the snippet after the opening body
tag. Specify the environment and whether you want to load the tags synchronously or asynchronously. (Asynchronously provides faster page loading. Amplitude's JavaScript SDK also loads asynchronously.)
1<script type="text/javascript"> 2var utag_data = { 3 "page_type": "home", 4 "customer_id": "t: feb-27" 5}; 6</script> 7 8 9<!-- Loading script asynchronously -->10<script type="text/javascript">11 (function(a,b,c,d){12 a='//tags.tiqcdn.com/utag/sbx-amplitud/main/prod/utag.js';13 b=document;c='script';d=b.createElement(c);d.src=a;d.type='text/java'+c;d.async=true;14 a=b.getElementsByTagName(c)[0];a.parentNode.insertBefore(d,a);15 })();16</script>
Make sure all variables you're adding to your instrumentation code have been defined in the Data Layer tab. Then, add an Amplitude vendor tag for any events you want to track. Tags can't have multiple variables mapped to the same destination; to send multiple events from the same page load, configure separate vendor tags for each. The destinations represent the different forms of data that you can send to Amplitude:
Tealium iQ uses data layers, which are a spec of the data that flow from a company's digital products and identifies events containing certain event attributes. After you define the data layer, you can install it across all your digital products and use that data for tag vendor configurations like Amplitude. The data layer is vendor-neutral, so you can instrument a data layer and then send it to many different vendor tags.
Include every data layer variable on your app in the Data Layer tab.
In the data layer, you can define the following variable types:
1<script type="text/javascript"> 2 var utag_data={ 3 "country_code": "US", 4 "currency_code": "USD", 5 "page_name": "Cart: View Shopping Bag", 6 "page_type": "cart", 7 "product_id": ["PROD123", "PROD456"], 8 "product_name": ["Red Shoes", "Black Socks"], 9 "product_category": ["Footwear", "Apparel"],10 "product_quantity": ["1", "2"],11 "product_unit_price": ["65.00", "4.75"],12 "cart_total_items": "3",13 "cart_subtotal": "74.00"14 };15</script>
http://example.com/path/file.html?sortOrder=price
, the variable name in Tealium is sortOrder
.utag_main
, or standard cookie. You can also add your own custom values to the utag_main cookie
. The utag.js
library creates and maintains a single cookie called utag_main
; within it are several built-in values that keep track of the visitor session.
ses_id
: Unique identifier for the session._st
: Unix/epoch time stamp in milliseconds.v_id
: Unique identifier for each visitor._ss
: Boolean that indicates if the page viewed is the first in a session. A value of 1 means yes and 0 means no._pn
: Number of pages viewed during the current session._sn
: The number of sessions for this visitor.utag_data
object.Load rules are conditions that define when and where to load a tag. They consist of logical conditions that must pass before Amplitude loads a tag. For example, you can set it up so that only certain tags load on certain domains. You can use AND/OR logic or time/date-based conditions to load tags.
You can delete load rules when they're no longer useful to you, or just deactivate them if you think you might use them again in the future.
Device ID
is set to the randomly generated UUID set by Amplitude's JavaScript SDK. Library = 'amplitude-js'
.utag.js
. Otherwise, it's ignored. Here is a UDO on the initial page load:1<script type="text/javascript">2var utag_data = {3 "page_type": "landing", // page type4 "page_name": "Home Page", // page name5 "event_name": "",6 "customer_id": "t: mar-20",7 "button_counter": "0"8};9</script>
To trigger another event when users click a button on the page and increment the button_counter
variable by one each time:.
1<script type = "text/javascript"> 2 document.addEventListener("DOMContentLoaded", function () { 3 document.querySelectorAll(".amp-track").forEach(function (element) { 4 element.addEventListener("click", function () { 5 var eventName = element.dataset.event; 6 if (eventName == "resume") { 7 utag.link({ 8 "button_counter": "1", 9 "event_name": "t: button clicked"10 });11 }12 });13 });14 });15</script>
You can configure the different SDK settings by mapping variables to the available destinations.
Thanks for your feedback!
April 22nd, 2024
Need help? Contact Support
Visit Amplitude.com
Have a look at the Amplitude Blog
Learn more at Amplitude Academy
© 2025 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.