使用带有window.onload的谷歌分析跟踪器功能

时间:2016-07-04 09:31:51

标签: javascript google-analytics window window.onunload

我正在我的网站上运行另一个名为" mylivechat"并且想要跟踪mylivechat popunder中的一个div。

但是,mylivechat脚本似乎耗费了太长时间,并且无法通过Google分析进行跟踪。

这是我用来跟踪mylivechat应用程序div的代码:

<script type="text/javascript" async defer data-cfasync="false" src="https://mylivechat.com/chatinline.aspx?hccid=68268000"></script>
<script type="text/javascript" src="js/jquery.min.js"></script>          

<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('send', 'pageview');

        ga(function(tracker) {
          //console.log(tracker.get('clientId'));
          var CID = tracker.get('clientId');

          var myl = document.querySelector('div.mylivechat_collapsed');
          myl.addEventListener('click', function() {
             console.log('CLICK:',CID);
             ga('send', 'event', 'contact', 'livechat' , CID);
          });
        });

</script>

如果我将ga跟踪器功能放在window.onload函数中,我可以让它工作,如下所示 - 它等待首先加载脚本。

<script type="text/javascript" async defer data-cfasync="false" src="https://mylivechat.com/chatinline.aspx?hccid=68268000"></script>
<script type="text/javascript" src="js/jquery.min.js"></script>          

<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-xxxxxxx-1', 'auto');
    ga('send', 'pageview');

    window.onload = function () { 
        ga(function(tracker) {
          //console.log(tracker.get('clientId'));
          var CID = tracker.get('clientId');

          var myl = document.querySelector('div.mylivechat_collapsed');
          myl.addEventListener('click', function() {
             console.log('CLICK:',CID);
             ga('send', 'event', 'contact', 'livechat' , CID);
          });
        });
    }



</script>

但是,我想知道这有什么影响?它适用于大多数浏览器吗?有没有更好的办法?

0 个答案:

没有答案