Я создаю платформу в стиле Google Analytics, которая работает с довольно стандартным потоком:
- Пользователи получают и настраивают фрагмент JS с уникальными параметрами учетной записи.
- Они встраивают этот фрагмент JS на свой веб-сайт, который асинхронно загружает мою основную библиотеку.
- После загрузки библиотеки пользователи могут вызывать ее методы для отправки данных в мое веб-приложение.
Изучив несколько различных реализаций того, как разные компании справляются с описанным выше потоком, я обнаружил, что новый от Google Тег Universal Analytics кажется наиболее элегантным по следующей причине:
Кажется, это позволяет пользователям вызывать методы, пока основная библиотека все еще асинхронно загружается, и все это внутри одного тега <script type="text/javascript">
.
Пример этого можно найти прямо в коде быстрого старта:
<!-- 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','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-XXXX-Y', 'auto');
ga('send', 'pageview');
</script>
<!-- End Google Analytics -->
Я пытаюсь понять, как это позволяет пользователю вызывать ga('create' ... )
и ga('send' ... )
, в то время как основная анонимная функция все еще предположительно манипулирует DOM и вставляет/загружает скрипт analytics.js
.
Кто-нибудь знает, как работает приведенный выше шаблон?
Попытка обратного проектирования их минимизированного кода, по-видимому, предполагает, что они могут создавать пустой объект ga
, который эффективно действует как очередь сообщений, пока не загрузится основная библиотека. Затем, когда библиотека загружается, она, похоже, анализирует объект очереди и делает то, что ему нужно (поскольку она сможет фактически выполнять свои задачи, учитывая, что библиотека загружена).
Я не уверен на 100%, правильно ли вышеизложенное, так как немного сложно перепроектировать весь их код.
Я создал аналогичную реализацию, в которой я использую объект window.tempDataWhileLibraryHasntLoaded
для хранения всех данных, вызываемых такими методами, как ga("send" ...)
, до загрузки библиотеки. Затем библиотека анализирует этот объект, обрабатывает то, что ей нужно, и обнуляет объект, однако это не так. не кажется таким же чистым, как реализация Google.