Библиотеки Google Analytics
Мир развивается настолько быстро, что стоять на месте просто невозможно. Новые сервисы, новые способы коммуникации, обновленные интерфейсы, алгоритмы, технологии… Все это открывает человечеству безграничные возможности. То, что было придумано вчера, завтра может быть уже неактуальным.
Поэтому так важно идти в ногу со временем, подстраиваться под быстро меняющиеся условия рынка, всегда быть в движении, и предоставлять своим клиентам удобный сервис и конкурентоспособный продукт.
Если вышесказанное спроецировать на конкретный инструмент компании Google, то все это тоже верно. Ежедневно компания выпускает десятки и сотни различных обновлений во всех своих продуктах – от небольших изменений алгоритмов в поисковой системе до смены расположения элементов в интерфейсе, добавлении новых функций и прекращении поддержки старых технологий.
За последние 10 лет в одном только Google Analytics было столько обновлений (существенных и не очень), что описать их все в одной статье просто не представляется возможным. Да это и не нужно, поскольку практической пользы от этого не так много. А вот поговорить о наиболее важных событиях в жизни самого популярного инструмента веб-аналитики все же стоит. И речь пойдет о библиотеках Google Analytics.
Библиотека JavaScript — сборник классов и/или функций на языке JavaScript. Google имеет свои собственные клиентские библиотеки для самых распространенных языков программирования (PHP, Java, Python, JavaScript), чтобы упростить использование API.
Поскольку код отслеживания Google Analytics – это фрагмент кода JavaScript, то он тоже работает с различными библиотеками. С 2009 года они изменялись 4 раза:
- urchin.js (до 2009);
- ga.js (до 2013);
- analytics.js (с 2013);
- gtag.js (с 2017);
Когда вам необходимо настроить события на сайте, изменив код счетчика, апгрейдить показатель отказов, внедрить электронную торговлю, настроить междоменное отслеживание, функцию User ID и т.д., вы должны понимать, что такое библиотека и какие конструкции кодов следует использовать в зависимости от нее.
urchin.js
Устаревшая библиотека, которая использовалась до 2009 года. Название сопряжено с названием компании Urchin Software Corp., историю которой можно прочитать в этой статье.
Код Google Analytics когда-то выглядел так:
1 2 3 4 5 6 |
<script scr="http://www.google-analytics.com/urchin.js" type="text/javascript"> </script> <script type="text/javascript"> _uacct = "UA-XXXX-Y"; urchinTracker(); </script> |
Документация по продукту Urchin доступна по ссылке на английском языке с пометкой:
Поддержка программного обеспечения Urchin WebAnalytics прекращена и больше не поддерживается. Вся документация Urchin применяется только к продукту Urchin и не распространяется на какие-либо продукты или услуги Google Analytics.
Сам продукт Urchin до сих пор используют различные компании как инструмент анализа веб-статистики. Он анализирует журнал веб-сервера и отображает информацию о трафике на основе данных этого журнала.
Urchin Software Corp. была приобретена компанией Google в апреле 2005 года и переименована в Google Analytics. В апреле 2008 года Google выпустила Urchin 6. В феврале 2009 года Google выпустила Urchin 6.5, интегрировав его с Google AdWords. Urchin 7 был выпущен в сентябре 2010 года и включал в себя 64-битную поддержку, новый интерфейс, отслеживание событий и ряд других функций.
Классическая библиотека ga.js
В 2009 году появилась новая библиотека ga.js и код, который стал работать асинхронно, то есть стал загружаться в фоновом режиме, без приостановки загрузки других скриптов и контента на страницах веб-сайта.
Код Google Analytics выглядел так:
1 2 3 4 5 6 7 8 9 10 |
<script type="text/javascript"> var _gaq = _gaq || []; _gaq.push(['_setAccount', 'UA-XXXXX-X']); _gaq.push(['_trackPageview']); (function() { var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true; ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s); })(); </script> |
Конструкция передачи событий в библиотеке ga.js:
1 |
_trackEvent(category, action, opt_label, opt_value, opt_noninteraction) |
Электронная торговля:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
_gaq.push(['_addTrans', '1234', // transaction ID - required 'Acme Clothing', // affiliation or store name '11.99', // total - required '1.29', // tax '5', // shipping 'San Jose', // city 'California', // state or province 'USA' // country ]); _gaq.push(['_addItem', '1234', // transaction ID - required 'DD44', // SKU/code - required 'T-Shirt', // product name 'Green Medium', // category or variation '11.99', // unit price - required '1' // quantity - required ]); _gaq.push(['_trackTrans']); //submits transaction to the Analytics servers |
На данный момент является устаревшей библиотекой. Ее не рекомендуется использовать. Поэтому, когда вы читаете в интернете различные статьи по Google Analytics, обязательно смотрите на дату публикации материала. Все, что старее 2014-2015 годов, сейчас уже не работает.
Документация по классической библиотеке ga.js доступна по ссылке на английском языке с пометкой:
ga.js - это устаревшая библиотека. Если вы начинаете новую реализацию, мы рекомендуем использовать последнюю версию этой библиотеки analytics.js. Для существующих реализаций узнайте, как перейти от ga.js к analytics.js.
Universal Analytics, библиотека analytics.js
На данный момент (по состоянию на октябрь 2018) является самой популярной и самой стабильной библиотекой Google Analytics, несмотря на то, что уже есть gtag.js. Поддерживается различными сервисами автоматизации, управлениями рекламных кампаний, коллтрекингов, онлайн-консультантами и т.д.
Документация по библиотеке analytics.js доступна по ссылке на русском языке. Справка доступна здесь.
С 2013 года в Universal Analytics реализованы функции, которые позволяют на принципиально другом уровне работать с данными и анализировать взаимодействие пользователей с вашим контентом. Абсолютно новый подход к отслеживанию и огромное количество нововведений:
- Функция User ID
- Measurement Protocol
- Специальные параметры и показатели
- Расширенная электронная торговля (Enhanced Ecommerce)
- Дополнительные функции и обновления
Посмотреть, как осуществлялся переход с классической библиотеки ga.js на Universal Analytics можно в материале Ивана Иванова «Пошаговое руководство по переходу на Universal Analytics».
Код Universal Analytics выглядит так:
1 2 3 4 5 6 7 8 9 10 11 |
<!-- Google Analytics --> <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-XXXXX-Y', 'auto'); ga('send', 'pageview'); </script> <!-- End Google Analytics --> |
И альтернативный асинхронный код отслеживания выглядит так:
1 2 3 4 5 6 7 8 |
<!-- Google Analytics --> <script> window.ga=window.ga||function(){(ga.q=ga.q||[]).push(arguments)};ga.l=+new Date; ga('create', 'UA-XXXXX-Y', 'auto'); ga('send', 'pageview'); </script> <script async src='https://www.google-analytics.com/analytics.js'></script> <!-- End Google Analytics --> |
Вы можете использовать любой из них. Разница в том, что некоторые браузеры могут не поддерживать предварительную загрузку первого скрипта. Второй же (альтернативный), как правило, позволяет повысить производительность в современных браузерах.
Конструкция передачи событий в библиотеке analytics.js:
1 |
ga('send', 'event', [eventCategory], [eventAction], [eventLabel], [eventValue], [fieldsObject]); |
Электронная торговля:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
ga('ecommerce:addTransaction', { 'id': '1234', // Transaction ID. Required. 'affiliation': 'Acme Clothing', // Affiliation or store name. 'revenue': '11.99', // Grand Total. 'shipping': '5', // Shipping. 'tax': '1.29' // Tax. }); ga('ecommerce:addItem', { 'id': '1234', // Transaction ID. Required. 'name': 'Fluffy Pink Bunnies', // Product name. Required. 'sku': 'DD23444', // SKU/code. 'category': 'Party Toys', // Category or variation. 'price': '11.99', // Unit price. 'quantity': '1' // Quantity. }); ga('ecommerce:send'); |
Причем для использования электронной торговли необходимо в коде отслеживания подключить дополнительный плагин:
1 |
ga('require', 'ecommerce', 'ecommerce.js'); |
На смену analytics.js в августе 2017 года пришел Global Site Tag. С октября 2017 года он стал доступен для всех рекламодателей. Но это не просто обновление или новая библиотека, а совершенно другой подход к сбору данных. Нововведение предназначено для того, чтобы сделать единый централизованный тег, который отправляет данные во все маркетинговые и аналитические инструменты Google.
До текущей версии от каждого сервиса Google мы добавляли полный фрагмент кода на страницы веб-сайта. Для отслеживания конверсий – свой код, для тега ремаркетинга Google Рекламы – свой код, для инструмента Google Optimize – свой, плагин для включения электронной коммерции – еще фрагмент кода и т.д. Все это отдельные теги продуктов одной компании (Google).
Новый gtag.js упрощает все это. Теперь легко можно совмещать различные теги в одном месте вашего кода, проще подключать в работу разные продукты и отправлять данные сразу в несколько инструментов одновременно. Например, не дублировать полностью два кода Google Analytics, а добавить всего лишь одну строчку:
1 |
gtag('config', 'GA_TRACKING_ID_2'); |
, где GA_TRACKING_ID_2 - идентификатор отслеживания 2 ресурса.
Теперь всегда при создании нового счетчика Google Analytics код выглядит так:
1 2 3 4 5 6 7 8 9 |
<!-- Global site tag (gtag.js) - Google Analytics --> <script async src="https://www.googletagmanager.com/gtag/js?id= UA-XXXXX-Y"></script> <script> window.dataLayer = window.dataLayer || []; function gtag(){dataLayer.push(arguments);} gtag('js', new Date()); gtag('config', 'UA-XXXXX-Y'); </script> |
config - это команда, которая подтягивает соответствующую библиотеку для выбранного продукта, например analytics.js для Google Analytics или conversion.js для Google Рекламы.
Документация по gtag.js доступна по ссылке на русском языке.
Конструкция передачи событий в gtag.js:
1 2 3 4 5 6 |
gtag('event', , { 'event_category': , 'event_label': <label>, 'value': }); </label> |
Электронная торговля по событию «Покупка» (purchase):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
gtag('event', 'purchase', { "transaction_id": "24.031608523954162", "affiliation": "Google online store", "value": 23.07, "currency": "USD", "tax": 1.24, "shipping": 0, "items": [ { "id": "P12345", "name": "Android Warhol T-Shirt", "list_name": "Search Results", "brand": "Google", "category": "Apparel/T-Shirts", "variant": "Black", "list_position": 1, "quantity": 2, "price": '2.0' }, { "id": "P67890", "name": "Flame challenge TShirt", "list_name": "Search Results", "brand": "MyBrand", "category": "Apparel/T-Shirts", "variant": "Red", "list_position": 2, "quantity": 1, "price": '3.0' } ] }); |
Библиотека analytics.js по-прежнему существует, просто в gtag.js она загружается в другом стиле. Если вы в настоящее время используете на странице analytics.js, нет необходимости спешить с переходом на gtag.js.
Как узнать какая библиотека установлена на сайте?
Самый простой способ – это зайти в аккаунт Google Analytics и на уровне ресурса в разделе «Отслеживание – Код отслеживания»
Однако во всех новых аккаунтах Google Analytics будет отображаться Global Site Tag, поэтому следует использовать другой способ.
Второй способ - это посмотреть какой скрипт/библиотека подгружается в коде.
gtag.js:
1 |
script async src="https://www.googletagmanager.com/gtag/js?id= UA-XXXXX-Y" |
analytics.js:
1 |
script async src='https://www.google-analytics.com/analytics.js' |
ga.js:
1 |
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js'; |
urchin.js:
1 |
script scr="http://www.google-analytics.com/urchin.js" type="text/javascript" |
Третий способ - воспользоваться консолью разработчика и на вкладке «Сеть (Network)» найти подгружаемые скрипты .js.
На моем блоге установлен Global Site Tag, однако кроме gtag подгружается и analytics.js. Так и должно быть. Открыв каждый скрипт по очереди легко в этом убедиться.
Примечание: на сайте могут одновременно использоваться обе библиотеки: как Universal Analytics (gtag.js и analytics.js), так и классическая (ga.js). Однако несколько экземпляров ga.js могут привести к неправильному сбору и обработке данных, а также к ошибкам в отчетах. При этом на веб-страницы, содержащие один экземпляр ga.js, можно установить один или несколько экземпляров analytics.js.
Таким образом, важно знать какой код отслеживания установлен на сайте для того, чтобы при дополнительных настройках Google Analytics использовать верные команды. Всегда, когда копируете какие-либо конструкции из чужих статей, блогов и документаций, проверяйте «свежесть» и актуальность информации.