首页 > 解决方案 > Google 跟踪代码管理器访问数据层对象值

问题描述

我正在尝试在添加到购物车事件时访问数据层变量,但它没有在标签管理器管理站点上得到跟踪

*事件被触发但值未发送

数据层推送:

<script>
  dataLayer.push({
    'event': 'addToCart', 
    'ecommerce': {
      'currencyCode': 'EUR', 
      'add': {
        'products': [
          {
            'name': 'test',
            'id': 'ZZZ232323',
            'price': 33,
            'brand': '',
            'category': 'test',
            'variant': '','quantity': 1
          }
        ]
      }
    }
  });
</script>

我正在尝试访问数据层以使用以下方式获取产品名称:

dataLayer.find(x => x.event == 'addToCart').ecommerce.add.products[dataLayer.find(x => x.event == 'addToCart').ecommerce.add.products.length - 1].price

谷歌标签管理器网站的图片

标签: google-tag-managergoogle-datalayer

解决方案


数据层变量不需要引用数据层的特定步骤(数组元素)。当您创建对 dataLayer 变量的引用时,例如ecommerce,Google 跟踪代码管理器 (GTM) 将尝试在任何给定的 GTM 事件中评估它,但会退回到undefined或您指定的任何其他值。

这意味着,如果您在产品数据可用时触发 Facebook Pixel 跟踪代码(事件 = addToCart),则对电子商务数据的正确引用将具有价值。有几个选项可以获取您的产品名称。

您可以创建一个通用的“电子商务”变量,引用ecommerce为数据层变量名称。在您的 Facebook Pixel 相关代码中,您将不得不走到所需的变量,并注意任何可能的缺失值。但是,此电子商务变量可用于多个标签。

var productName = {{Ecommerce}}.add.products[0].name; //assuming you'll always have just one product in products array

或者,您可以选择一个特定变量,在其中设置“电子商务 - 添加到购物车的产品名称”,您可以在其中引用ecommerce.add.products[0].name. 这样,您可以简单地将这个变量分配给正确的 Facebook Pixel 变量,使用{{Ecommerce - name of product added to cart}}


推荐阅读