Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Я пытаюсь внедрить диспетчер тегов Google в реагирующее приложение. Он работает при перезагрузке страницы, но когда я перемещаюсь между своим приложением по маршрутам, он не регистрирует просмотр страницы в аналитике Google.

Я пробовал react-gtm-module, но он также работает при перезагрузке, а не при изменении маршрута.

index.html добавлен код ниже в теге head.

<!-- 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','GTM-XXXX');</script>
<!-- End Google Tag Manager -->

добавлен код ниже в теге body.

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

и внутри моих компонентов componentDidMount я вставляю новые pageView в dataLayer

dataLayer.push({
    event: 'Pageview',
    pagePath: 'page-path-here',
    pageTitle: 'page-title-here',
});

Я создал переменные pagePath и pageTitle dataLayer и присвоил их тегу Google Analytics. Я также создал собственный триггерPageView и добавил его в триггеры запуска в теге Google Analytics.

Переменные уровня данных Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Пользовательские триггеры Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Назначение переменных уровня данных тегу Analytics Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Может ли кто-нибудь указать мне правильное направление?

Редактировать: Представление переменных уровня данных подробностей Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Первая загрузка (перезагрузка) Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Изменение маршрута Диспетчер тегов Google не отправляет запрос аналитики после изменения маршрута

Настройка вроде правильная, хотя подробные настройки переменных в пост не включены. Что вы видите в представлении отладки GTM? Вы видите событие? Каковы значения переменных? Какие теги активируются?

kgrg 28.06.2019 08:47

@kgrg Я вижу, что событие отправляется при первой загрузке. Изменение маршрута не запускает триггер pageView. Нужно ли мне что-то делать после нажатия на dataLayer, например, вызывать любую функцию диспетчера тегов?

Barcenal 28.06.2019 09:21
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
4
2
3 969
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Код, который вы написали в index.html, запускается только один раз при загрузке страницы, если вы хотите зарегистрировать событие при изменении страницы, вам нужно инициировать то же самое на маршрутах, которые вы хотите инициировать, вы можете получить доступ к переменной dataLayer из window

Ответ принят как подходящий

Я изменил свой код componentDidMount на

window.dataLayer = window.dataLayer || [];
window.dataLayer.push({
    event: 'Pageview',
    pagePath: 'page-path-here',
    pageTitle: 'page-title-here',
});

Отправка уровня данных

Теперь я могу видеть просмотры страниц в Google Analytics при изменении маршрута.

Другие вопросы по теме