有没有办法在 iFrame 中附加一个侦听器,当浏览器窗口获得焦点(单击选项卡或标题栏)时将调用该侦听器?这是测试代码:
测试.html:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><body><iframe src="test1.html"></iframe></body></html>
测试1.html:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html><head><script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script></head><body><script type="text/javascript">
var doc = $(window.top.document);
var win = $(window.top);
doc.ready(function(){
win.focus(function() { console.log('Focus'); });
win.blur(function() { console.log('Blur'); });
doc.mousemove(function() { console.log('Move'); });
});
</script></body></html>
点击 test.html,mousemove 侦听器被调用,但焦点和模糊仅在 iFrame 被点击和关闭时被调用,而不是在浏览器窗口获得/失去焦点时被调用。我尝试将侦听器附加到 doc 并以相同的结果获胜。我正在 Chrome 和 Firefox 中进行测试。