Google Tag Manager基础代码的原理解析

Google Tag Manager Haran 8年前 (2017-03-20) 5469次浏览 0个评论

更新时间:2025年1月11号

Google Tag Manager基础代码,也称为容器代码,是在你的网页中添加的一个小片段,它允许GTM管理和部署各种标签(例如跟踪代码、广告代码等)而不必直接编辑你的网站代码。

以下是GTM基础代码的工作原理:

代码结构

GTM基础代码通常是以下形式的JavaScript片段:

<!-- Google Tag Manager -->
<script>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start':
new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0],
j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src=
'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);
})(window,document,'script','dataLayer','<a href="https://www.ichdata.com/tag/gtm" title="查看更多关于GTM的文章" target="_blank">GTM</a>-MQ8Z6H');</script>
<!-- End Google Tag Manager -->

<!-- Google Tag Manager (noscript) --><noscript><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-MQ8Z6H" height="0" width="0" style="display:none;visibility:hidden"></iframe></noscript><!-- End Google Tag Manager (noscript) -->

其中,GTM-XXXXXXX 是你的容器ID,每个GTM容器都有自己独特的ID。

 

原理与工作流程

  1. 初始化数据层代码首先检查是否已经存在名为dataLayer的数组(或你自定义的名称)。如果没有,它会创建一个空数组。数据层是GTM与网页交流的主要方式,用于传递事件和数据。
  2. 推送初始事件代码向数据层推送一个名为gtm.js的事件,并记录当前时间(gtm.start)。这个事件标志着GTM已经开始加载。
  3. 加载GTM容器脚本创建一个新的<script>标签,并设置其源地址为GTM的服务器(googletagmanager.com/gtm.js),加上容器ID。这个脚本是异步加载的,不会阻塞页面其他资源的加载。
  4. 执行GTM逻辑一旦GTM的脚本加载并执行,它会处理数据层中的事件,应用你配置的标签和触发器。GTM会根据这些配置决定何时执行哪些标签。
  5. 管理标签GTM容器脚本会读取你在GTM界面中配置的所有标签和触发器。它会根据触发条件(如页面视图、点击事件等)决定是否执行标签。这些标签可以是GA跟踪代码、广告转换代码、自定义JavaScript等。
  6. 动态注入如果有标签需要在页面上执行(例如插入自定义HTML),GTM会动态地将这些代码注入到页面中。这意味着你可以添加或修改跟踪代码而无需直接接触网站代码。

 

优点

  • 灵活性:可以快速更改标签配置,无需重新部署网站。
  • 集中管理:通过GTM界面集中管理所有标签,简化了维护工作。
  • 安全性:减少了直接编辑网站源代码的需要,降低了潜在错误或安全问题的风险。

 

注意事项

  • 性能:虽然代码是异步的,但大量标签可能影响页面加载速度。
  • 隐私:需要考虑用户同意和隐私法规,确保标签在适当的用户同意下执行。

如有疑问,可以在文章底部留言或邮件(haran.huang@ichdata.com) 我~
喜欢 (2)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址