有没有办法用其他元素“封装”一个 Iframe 来模拟 onClick?我知道 iframe 不支持事件,但我需要跟踪从我的网站离开 iframe 的点击。
谢谢!
有没有办法用其他元素“封装”一个 Iframe 来模拟 onClick?我知道 iframe 不支持事件,但我需要跟踪从我的网站离开 iframe 的点击。
谢谢!
如果框架包含来自同一域的页面(不违反同源策略),您可以直接与其文档交互:
<script type="text/javascript">
window.onload = function() {
var oFrame = document.getElementById("myframe");
oFrame.contentWindow.document.onclick = function() {
alert("frame contents clicked");
};
};
</script>
如果它包含外部页面,那么你就不走运了——出于明显的安全原因,无法做你想做的事。尽管所有内容在视觉上都是同一页面的一部分,但来自不同域的框架必须在脚本方面保持独立。否则,任何页面都可能创建一个隐藏的 iframe,加载您的网络邮件并从中窃取您的会话 cookie。用户可以访问所有数据,但页面作者不应访问这些数据。
尝试使用:https ://github.com/vincepare/iframeTracker-jquery
由于同源策略无法从父页面读取 iframe 内容 (DOM),因此跟踪基于与页面/iframe 边界监控系统关联的模糊事件,随时告知哪个 iframe 是鼠标光标。
将要跟踪的 iframe 元素与 jQuery 选择器匹配,并使用回调函数调用 iframeTracker,该回调函数将在检测到点击 iframe 时调用:
jQuery(document).ready(function($){
$('.iframe_wrap iframe').iframeTracker({
blurCallback: function(){
// Do something when the iframe is clicked (like firing an XHR request)
}
});
});
还有更多选择。
上面的脚本非常适合测试 iframe 中的点击功能。更具体地说,如果您使用 Google 较新的analytics.js跟踪代码和事件跟踪来跟踪 iframe 中的点击,上面的代码将如下所示:
<script type="text/javascript">
window.onload = function() {
var oFrame = document.getElementById("myframe");
oFrame.contentWindow.document.onclick = function() {
ga('send', 'event', 'link', 'click', 'My Frame Was Clicked');
};
};
</script>
iframe 可能看起来像这样(注意 id="myframe" 在 javascript 中被引用):
<iframe id="myframe" src="http://www.yourowndomain.com" scrolling="yes" marginwidth="0" marginheight="0" vspace="0" hspace="0" height="800" style="border:0; overflow:hidden; width:100%;"></iframe>
然后测试事件点击,如果您熟悉 Google 的事件跟踪,在 Google Analytics(分析)仪表板中的标准报告 > 实时 > 事件下,点击将显示为事件操作:点击,事件标签:我的框架被点击。或长期在仪表板中的行为 > 事件下。
我已经对此进行了测试,并且正如之前的海报所指出的那样,这仅在 iframe 源位于同一域上时才有效。