{"id":10243,"date":"2024-10-28T22:00:25","date_gmt":"2024-10-28T22:00:25","guid":{"rendered":"https:\/\/ceowebltd.com\/blog\/?p=10243"},"modified":"2024-10-28T22:00:25","modified_gmt":"2024-10-28T22:00:25","slug":"how-to-track-dynamic-content-with-google-tag-manager","status":"publish","type":"post","link":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/","title":{"rendered":"How to track dynamic content with Google Tag Manager"},"content":{"rendered":"<p>Tracking dynamic content with Google Tag Manager (GTM) allows you to capture user interactions and changes to content that occurs without a full page reload. This is especially important for single-page applications (SPAs) or websites that use AJAX to load new content. Here&#8217;s a step-by-step guide on how to track dynamic content with Google Tag Manager effectively.<\/p>\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_73 counter-hierarchy ez-toc-counter ez-toc-grey ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">Table of Contents<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step-by-Step_Guide_to_Tracking_Dynamic_Content_with_Google_Tag_Manager\" title=\"Step-by-Step Guide to Tracking Dynamic Content with Google Tag Manager\">Step-by-Step Guide to Tracking Dynamic Content with Google Tag Manager<\/a><ul class='ez-toc-list-level-4' ><li class='ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_1_Set_Up_Google_Tag_Manager\" title=\"Step 1: Set Up Google Tag Manager\">Step 1: Set Up Google Tag Manager<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_2_Identify_Dynamic_Content\" title=\"Step 2: Identify Dynamic Content\">Step 2: Identify Dynamic Content<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_3_Create_Data_Layer_Events\" title=\"Step 3: Create Data Layer Events\">Step 3: Create Data Layer Events<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_4_Create_a_Trigger_in_GTM\" title=\"Step 4: Create a Trigger in GTM\">Step 4: Create a Trigger in GTM<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_5_Create_a_Tag_to_Capture_the_Event\" title=\"Step 5: Create a Tag to Capture the Event\">Step 5: Create a Tag to Capture the Event<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_6_Preview_and_Debug\" title=\"Step 6: Preview and Debug\">Step 6: Preview and Debug<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_7_Publish_Your_Changes\" title=\"Step 7: Publish Your Changes\">Step 7: Publish Your Changes<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-4'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Step_8_Monitor_Data_in_Analytics\" title=\"Step 8: Monitor Data in Analytics\">Step 8: Monitor Data in Analytics<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Additional_Considerations\" title=\"Additional Considerations\">Additional Considerations<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#Conclusion\" title=\"Conclusion\">Conclusion<\/a><\/li><\/ul><\/nav><\/div>\n<h3><span class=\"ez-toc-section\" id=\"Step-by-Step_Guide_to_Tracking_Dynamic_Content_with_Google_Tag_Manager\"><\/span>Step-by-Step Guide to Tracking Dynamic Content with Google Tag Manager<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<h4><span class=\"ez-toc-section\" id=\"Step_1_Set_Up_Google_Tag_Manager\"><\/span>Step 1: Set Up Google Tag Manager<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Create or Access Your GTM Account:<\/strong>\n<ul>\n<li>Go to the <a href=\"https:\/\/tagmanager.google.com\" target=\"_new\" rel=\"noopener\">Google Tag Manager website<\/a>.<\/li>\n<li>If you already have an account, select it; otherwise, create a new account and container for your website.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Install GTM on Your Website:<\/strong>\n<ul>\n<li>Follow the instructions to add the GTM container code to your website. Ensure that it\u2019s placed in the <code>&lt;head&gt;<\/code> and <code>&lt;body&gt;<\/code> sections of your HTML.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_2_Identify_Dynamic_Content\"><\/span>Step 2: Identify Dynamic Content<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Define What You Want to Track:<\/strong>\n<ul>\n<li>Identify the dynamic elements on your site, such as product lists, user interactions (like button clicks), or content changes (e.g., when a user scrolls or selects a different tab).<\/li>\n<\/ul>\n<\/li>\n<li><strong>Inspect the Elements:<\/strong>\n<ul>\n<li>Use your browser\u2019s developer tools (usually accessible by right-clicking and selecting \u201cInspect\u201d) to examine the HTML structure of the dynamic content you wish to track.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_3_Create_Data_Layer_Events\"><\/span>Step 3: Create Data Layer Events<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<p>To track dynamic content changes, you\u2019ll typically want to push events to the Data Layer.<\/p>\n<ol>\n<li><strong>Push Events to the Data Layer:<\/strong>\n<ul>\n<li>Modify your website\u2019s JavaScript to push a custom event to the Data Layer when dynamic content changes occur. For example:<\/li>\n<\/ul>\n<div class=\"contain-inline-size rounded-md border-[0.5px] border-token-border-medium relative bg-token-sidebar-surface-primary dark:bg-gray-950\">\n<div class=\"flex items-center text-token-text-secondary px-4 py-2 text-xs font-sans justify-between rounded-t-md h-9 bg-token-sidebar-surface-primary dark:bg-token-main-surface-secondary\">javascript<\/div>\n<div class=\"sticky top-9 md:top-[5.75rem]\">\n<div class=\"absolute bottom-0 right-2 flex h-9 items-center\">\n<div class=\"flex items-center rounded bg-token-sidebar-surface-primary px-2 font-sans text-xs text-token-text-secondary dark:bg-token-main-surface-secondary\"><span class=\"\" data-state=\"closed\"><button class=\"flex gap-1 items-center py-1\">Copy code<\/button><\/span><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\"><code class=\"!whitespace-pre hljs language-javascript\"><span class=\"hljs-variable language_\">window<\/span>.<span class=\"hljs-property\">dataLayer<\/span> = <span class=\"hljs-variable language_\">window<\/span>.<span class=\"hljs-property\">dataLayer<\/span> || [];<br \/>\ndataLayer.<span class=\"hljs-title function_\">push<\/span>({<br \/>\n    <span class=\"hljs-string\">'event'<\/span>: <span class=\"hljs-string\">'dynamicContentChange'<\/span>,<br \/>\n    <span class=\"hljs-string\">'contentCategory'<\/span>: <span class=\"hljs-string\">'product'<\/span>,<br \/>\n    <span class=\"hljs-string\">'contentName'<\/span>: <span class=\"hljs-string\">'Product Name'<\/span>,<br \/>\n    <span class=\"hljs-string\">'contentID'<\/span>: <span class=\"hljs-string\">'12345'<\/span><br \/>\n});<br \/>\n<\/code><\/div>\n<\/div>\n<\/li>\n<li><strong>Trigger on Content Changes:<\/strong>\n<ul>\n<li>You can also set up a MutationObserver to monitor changes in the DOM if your site frequently updates dynamic content without page reloads:<\/li>\n<\/ul>\n<div class=\"contain-inline-size rounded-md border-[0.5px] border-token-border-medium relative bg-token-sidebar-surface-primary dark:bg-gray-950\">\n<div class=\"flex items-center text-token-text-secondary px-4 py-2 text-xs font-sans justify-between rounded-t-md h-9 bg-token-sidebar-surface-primary dark:bg-token-main-surface-secondary\">javascript<\/div>\n<div class=\"sticky top-9 md:top-[5.75rem]\">\n<div class=\"absolute bottom-0 right-2 flex h-9 items-center\">\n<div class=\"flex items-center rounded bg-token-sidebar-surface-primary px-2 font-sans text-xs text-token-text-secondary dark:bg-token-main-surface-secondary\"><span class=\"\" data-state=\"closed\"><button class=\"flex gap-1 items-center py-1\">Copy code<\/button><\/span><\/div>\n<\/div>\n<\/div>\n<div class=\"overflow-y-auto p-4\" dir=\"ltr\"><code class=\"!whitespace-pre hljs language-javascript\"><span class=\"hljs-keyword\">const<\/span> observer = <span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-title class_\">MutationObserver<\/span>(<span class=\"hljs-function\"><span class=\"hljs-params\">mutations<\/span> =&gt;<\/span> {<br \/>\n    mutations.<span class=\"hljs-title function_\">forEach<\/span>(<span class=\"hljs-function\"><span class=\"hljs-params\">mutation<\/span> =&gt;<\/span> {<br \/>\n        <span class=\"hljs-comment\">\/\/ Check for specific changes and push to the data layer<\/span><br \/>\n        <span class=\"hljs-keyword\">if<\/span> (mutation.<span class=\"hljs-property\">type<\/span> === <span class=\"hljs-string\">'childList'<\/span>) {<br \/>\n            dataLayer.<span class=\"hljs-title function_\">push<\/span>({<br \/>\n                <span class=\"hljs-string\">'event'<\/span>: <span class=\"hljs-string\">'dynamicContentChange'<\/span>,<br \/>\n                <span class=\"hljs-string\">'contentName'<\/span>: mutation.<span class=\"hljs-property\">target<\/span>.<span class=\"hljs-property\">innerText<\/span><br \/>\n            });<br \/>\n        }<br \/>\n    });<br \/>\n});<\/p>\n<p>observer.<span class=\"hljs-title function_\">observe<\/span>(<span class=\"hljs-variable language_\">document<\/span>.<span class=\"hljs-title function_\">getElementById<\/span>(<span class=\"hljs-string\">'yourDynamicElement'<\/span>), { <span class=\"hljs-attr\">childList<\/span>: <span class=\"hljs-literal\">true<\/span>, <span class=\"hljs-attr\">subtree<\/span>: <span class=\"hljs-literal\">true<\/span> });<br \/>\n<\/code><\/div>\n<\/div>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_4_Create_a_Trigger_in_GTM\"><\/span>Step 4: Create a Trigger in GTM<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Go to Triggers:<\/strong>\n<ul>\n<li>In your GTM container, click on <strong>&#8220;Triggers&#8221;<\/strong> in the left sidebar.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Create a New Trigger:<\/strong>\n<ul>\n<li>Click on <strong>&#8220;New.&#8221;<\/strong><\/li>\n<\/ul>\n<\/li>\n<li><strong>Choose Trigger Type:<\/strong>\n<ul>\n<li>Select <strong>&#8220;Custom Event&#8221;<\/strong> as the trigger type.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Configure the Trigger:<\/strong>\n<ul>\n<li>Set the trigger to listen for the event you defined earlier (e.g., <code>dynamicContentChange<\/code>).<\/li>\n<li>For the event name, enter the name of the event you pushed to the Data Layer.<\/li>\n<li>Choose whether to trigger on &#8220;All Custom Events&#8221; or &#8220;Some Custom Events&#8221; if you have specific conditions.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_5_Create_a_Tag_to_Capture_the_Event\"><\/span>Step 5: Create a Tag to Capture the Event<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Go to Tags:<\/strong>\n<ul>\n<li>Click on <strong>&#8220;Tags&#8221;<\/strong> in the left sidebar.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Create a New Tag:<\/strong>\n<ul>\n<li>Click on <strong>&#8220;New.&#8221;<\/strong><\/li>\n<\/ul>\n<\/li>\n<li><strong>Choose Tag Type:<\/strong>\n<ul>\n<li>Select a tag type depending on where you want to send the data (e.g., Google Analytics, Facebook Pixel, etc.).<\/li>\n<li>For Google Analytics, choose <strong>&#8220;Google Analytics: Universal Analytics&#8221;<\/strong> or <strong>&#8220;GA4 Event&#8221;<\/strong> based on your setup.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Configure Tag Settings:<\/strong>\n<ul>\n<li>Set the Track Type to <strong>&#8220;Event.&#8221;<\/strong><\/li>\n<li>Fill in the Event Category, Action, and Label fields based on the dynamic content data you\u2019re tracking. You can use variables to pull in values from the Data Layer.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Set Up the Trigger:<\/strong>\n<ul>\n<li>Under <strong>&#8220;Triggering,&#8221;<\/strong> select the trigger you created earlier (e.g., the custom event trigger for <code>dynamicContentChange<\/code>).<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_6_Preview_and_Debug\"><\/span>Step 6: Preview and Debug<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Enter Preview Mode:<\/strong>\n<ul>\n<li>Click on the <strong>&#8220;Preview&#8221;<\/strong> button in GTM to enable debug mode. This will allow you to see what tags are firing in real time.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Test the Implementation:<\/strong>\n<ul>\n<li>Interact with the dynamic content on your site. Ensure that the correct events are being pushed to the Data Layer and that the tags are firing as expected.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Check the Debug Console:<\/strong>\n<ul>\n<li>Use the GTM debug console to verify that the <code>dynamicContentChange<\/code> events are being captured and that the data is correct.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_7_Publish_Your_Changes\"><\/span>Step 7: Publish Your Changes<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Submit Your Changes:<\/strong>\n<ul>\n<li>If everything is functioning correctly in preview mode, click on the <strong>&#8220;Submit&#8221;<\/strong> button in GTM to publish your changes.<\/li>\n<\/ul>\n<\/li>\n<li><strong>Version Description:<\/strong>\n<ul>\n<li>Include a version description (e.g., &#8220;Set up dynamic content tracking&#8221;) for future reference.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h4><span class=\"ez-toc-section\" id=\"Step_8_Monitor_Data_in_Analytics\"><\/span>Step 8: Monitor Data in Analytics<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<ol>\n<li><strong>Check Your Analytics Account:<\/strong>\n<ul>\n<li>Log into Google Analytics or your chosen analytics platform.<\/li>\n<li>Navigate to the events section to ensure that the events you set up are being recorded correctly.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h3><span class=\"ez-toc-section\" id=\"Additional_Considerations\"><\/span>Additional Considerations<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<ul>\n<li><strong>Tracking Multiple Dynamic Elements:<\/strong> If your site has multiple dynamic elements, consider creating a more generic event structure in your data layer to simplify tracking.<\/li>\n<li><strong>Performance Impact:<\/strong> Excessive use of mutation observers can impact performance. Make sure to optimize your implementation based on your site&#8217;s requirements.<\/li>\n<li><strong>Data Privacy Compliance:<\/strong> Ensure that your tracking complies with privacy regulations, such as GDPR and CCPA, by informing users about data collection and obtaining necessary consent.<\/li>\n<\/ul>\n<h3><span class=\"ez-toc-section\" id=\"Conclusion\"><\/span>Conclusion<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>Tracking dynamic content with Google Tag Manager enables you to capture valuable user interactions and behavior on your site, even as content changes in real-time. By following the steps outlined above, you can effectively implement dynamic tracking, gather insights, and enhance your analytics strategy, leading to better decision-making and improved user experience. Regularly monitor your data to refine your tracking and ensure you are capturing the most relevant information.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Tracking dynamic content with Google Tag Manager (GTM) allows you to capture user interactions and changes to content that occurs without a full page reload&#8230;.<\/p>\n","protected":false},"author":214,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[3],"tags":[],"class_list":["post-10243","post","type-post","status-publish","format-standard","hentry","category-digital-marketing"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.0 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>How to track dynamic content with Google Tag Manager - CEOweb Ltd. Blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"How to track dynamic content with Google Tag Manager - CEOweb Ltd. Blog\" \/>\n<meta property=\"og:description\" content=\"Tracking dynamic content with Google Tag Manager (GTM) allows you to capture user interactions and changes to content that occurs without a full page reload....\" \/>\n<meta property=\"og:url\" content=\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/\" \/>\n<meta property=\"og:site_name\" content=\"CEOweb Ltd. Blog\" \/>\n<meta property=\"article:published_time\" content=\"2024-10-28T22:00:25+00:00\" \/>\n<meta name=\"author\" content=\"Emmanuel\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Emmanuel\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/\",\"url\":\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/\",\"name\":\"How to track dynamic content with Google Tag Manager - CEOweb Ltd. Blog\",\"isPartOf\":{\"@id\":\"https:\/\/ceowebltd.com\/blog\/#website\"},\"datePublished\":\"2024-10-28T22:00:25+00:00\",\"dateModified\":\"2024-10-28T22:00:25+00:00\",\"author\":{\"@id\":\"https:\/\/ceowebltd.com\/blog\/#\/schema\/person\/4759c204c0b0f1d134ec16e8ec777a6f\"},\"breadcrumb\":{\"@id\":\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/ceowebltd.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"How to track dynamic content with Google Tag Manager\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/ceowebltd.com\/blog\/#website\",\"url\":\"https:\/\/ceowebltd.com\/blog\/\",\"name\":\"CEOweb Ltd. Blog\",\"description\":\"Guest Posting - Digital Marketing &amp; Web Services\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/ceowebltd.com\/blog\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/ceowebltd.com\/blog\/#\/schema\/person\/4759c204c0b0f1d134ec16e8ec777a6f\",\"name\":\"Emmanuel\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/ceowebltd.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/9e883d40261b9b272de51992551b3eec4df631b7579a4fbec69c36a006dcbaf2?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/9e883d40261b9b272de51992551b3eec4df631b7579a4fbec69c36a006dcbaf2?s=96&d=mm&r=g\",\"caption\":\"Emmanuel\"},\"url\":\"https:\/\/ceowebltd.com\/blog\/author\/emmanuel\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"How to track dynamic content with Google Tag Manager - CEOweb Ltd. Blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/","og_locale":"en_US","og_type":"article","og_title":"How to track dynamic content with Google Tag Manager - CEOweb Ltd. Blog","og_description":"Tracking dynamic content with Google Tag Manager (GTM) allows you to capture user interactions and changes to content that occurs without a full page reload....","og_url":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/","og_site_name":"CEOweb Ltd. Blog","article_published_time":"2024-10-28T22:00:25+00:00","author":"Emmanuel","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Emmanuel","Est. reading time":"4 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/","url":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/","name":"How to track dynamic content with Google Tag Manager - CEOweb Ltd. Blog","isPartOf":{"@id":"https:\/\/ceowebltd.com\/blog\/#website"},"datePublished":"2024-10-28T22:00:25+00:00","dateModified":"2024-10-28T22:00:25+00:00","author":{"@id":"https:\/\/ceowebltd.com\/blog\/#\/schema\/person\/4759c204c0b0f1d134ec16e8ec777a6f"},"breadcrumb":{"@id":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/ceowebltd.com\/blog\/how-to-track-dynamic-content-with-google-tag-manager\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/ceowebltd.com\/blog\/"},{"@type":"ListItem","position":2,"name":"How to track dynamic content with Google Tag Manager"}]},{"@type":"WebSite","@id":"https:\/\/ceowebltd.com\/blog\/#website","url":"https:\/\/ceowebltd.com\/blog\/","name":"CEOweb Ltd. Blog","description":"Guest Posting - Digital Marketing &amp; Web Services","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/ceowebltd.com\/blog\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/ceowebltd.com\/blog\/#\/schema\/person\/4759c204c0b0f1d134ec16e8ec777a6f","name":"Emmanuel","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/ceowebltd.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/9e883d40261b9b272de51992551b3eec4df631b7579a4fbec69c36a006dcbaf2?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/9e883d40261b9b272de51992551b3eec4df631b7579a4fbec69c36a006dcbaf2?s=96&d=mm&r=g","caption":"Emmanuel"},"url":"https:\/\/ceowebltd.com\/blog\/author\/emmanuel\/"}]}},"_links":{"self":[{"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/posts\/10243","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/users\/214"}],"replies":[{"embeddable":true,"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/comments?post=10243"}],"version-history":[{"count":1,"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/posts\/10243\/revisions"}],"predecessor-version":[{"id":10244,"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/posts\/10243\/revisions\/10244"}],"wp:attachment":[{"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/media?parent=10243"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/categories?post=10243"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ceowebltd.com\/blog\/wp-json\/wp\/v2\/tags?post=10243"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}