Весь скрипт для Google Analytics для отслеживания пользовательских размеров в JS
У меня были проблемы с отслеживанием пользовательских размеров с нашей GA. Я нашел несколько примеров кода в официальной документации и некоторых блогах. Все они отличаются друг от друга.
К концу я реализовал следующий фрагмент кода:
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-XXXXXXX-1"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'UA-XXXXXXX-1',{custom_map:{'dimension1':'semana'}});
gtag('send', 'pageview', { 'semana':'semana 11' }); // first attempt
gtag('event', 'pageview', { 'semana':'semana 12' }); // second attempt
ga('set', 'dimension1', 'semana 3'); // third attempt. ERROR: ga is not defined
</script>
(где хххххх ир наш идентификатор)
Я также создаю собственное измерение в учетной записи GA. однако я не вижу отслеживания созданного пользовательского измерения. Я подозреваю, что эти события не отправляются в ГА.
Я делаю что-то неправильно? Я не могу видеть наши пользовательские измерения, отслеживаемые GA, как показано ниже (yeelow mark - это пользовательское измерение)
В таком случае, каков полный код Javascript, который позволяет мне правильно отслеживать пользовательское измерение на нашем веб-сайте?
2 ответа
Что работает для меня было.
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-xxxxxx-1', 'auto');
ga('set', 'dimension1', 'semana 3');
ga('send', 'pageview');
</script>
Вы уверены, что пользовательское измерение в Google Analytics имеет идентификатор "1"?
Ваш первый пример генерирует ошибку, потому что код gtag() и вы вызываете ga(), который не существует, но второй код должен работать правильно.