我有一个网站使用的Mozilla PDF.js的iFrame的PDF格式,像这样:谷歌分析事件一个Mozilla PDF.js PDF中跟踪
<iframe class="maxit" src="web/viewer.html?file=MaxIT.pdf#zoom=page-fit" frameborder="0">
<embed class="maxit" src="web/viewer.html?file=MaxIT.pdf" type="">
</iframe>
,我使用从谷歌的analytics.js跟踪页面,像这样:
<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-XX', 'auto');
ga('send', 'pageview');
</script>
一切都会按计划,甚至标准的事件在页面上跟踪。 我的问题是,我无法通过单击pdf中的链接来跟踪事件。例如,我有一对夫妇邮件的PDF链接,我想跟踪。我正在使用以下脚本将事件发送到GA,但即使将脚本和analytics.js直接放在web/viewer.html页面上,也没有任何反应。这是我正在使用的脚本:
<script type="text/javascript">
$("a").each(function() {
var href = $(this).attr("href");
var target = $(this).attr("target");
var text = $(this).text();
$(this).click(function(event) { // when someone clicks these links
event.preventDefault(); // don't open the link yet
if (href.indexOf("mailto") !== -1) {
ga('send', 'event', {
'eventCategory': "mailto link",
'eventAction': "clicked",
'eventLabel': href,
'transport': 'beacon'
}); // create a custom event
console.log("mailto clicked");
}
setTimeout(function() { // now wait 300 milliseconds...
window.parent.open(href, (!target ? "_self" : target)); // ...and open the link as usual
}, 300);
});
});
</script>
上面的脚本工作正常,只是不适用于pdf中的链接。
请注意,PDF.js动态创建链接,因此您需要在每次渲染页面和创建注记图层时运行脚本。或者不要使用jQuery并通过单个document.addEventListener('click',handler,true)监听点击事件; – async5
当然,这工作。谢谢您的回答。 – StefanL