我正在我的网站上运行另一个名为“mylivechat”的脚本,并希望跟踪 mylivechat popunder 中的一个 div。
但是,mylivechat 脚本的加载时间似乎太长,并且没有被谷歌分析跟踪。
这是我用来从 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 tracker 函数放在 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>
但是,我想知道这有什么影响?它可以在大多数浏览器中使用吗?有没有更好的办法?