为iframe添加onclick事件

假设我们做一个下拉框的功能,当鼠标在页面上的其它位置点击一下时,这个下拉框就隐藏掉了,通常在没有iframe时,这个功能很容易做,给document绑定onmousedown或onclick即可,利于事件的冒泡机制即可轻松完成需求,当然记得给下拉框取消事件冒泡

如果页面上有iframe时,鼠标点击在iframe内时,包含iframe的document是不响应任何事件的,所以需要给iframe绑定类似的事件,当iframe指向的是第三方的内容时,还在考虑跨域的问题,因此通过操作iframe的document是行不通的,还好有document.activeElement可供我们使用,最终的解决方案如下:

var IframeOnClick = {
 resolution: 200,
 iframes: [],
 interval: null,
 Iframe: function() {
  this.element = arguments[0];
  this.cb = arguments[1]; 

  this.hasTracked = false;
 },
 track: function(element, cb) {
  this.iframes.push(new this.Iframe(element, cb));
  if (!this.interval) {
   var _this = this;
   this.interval = setInterval(function() { _this.checkClick(); }, this.resolution);
  }
 },

 checkClick: function() {
  if (document.activeElement) {
   var activeElement = document.activeElement;
   for (var i in this.iframes) {
    if (activeElement === this.iframes[i].element) { // user is in this Iframe
     if (this.iframes[i].hasTracked == false) {
      this.iframes[i].cb.apply(window, []); 

      this.iframes[i].hasTracked = true;
     }
    } else {
     this.iframes[i].hasTracked = false;
    }
   }
  }
 }
};

使用:

 <iframe src="http://www.baidu.com" id="iframe" style=""></iframe>
<script type="text/javascript">
IframeOnClick.track(document.getElementById("iframe"), function() { alert(‘a click‘); });
</script>

  

时间: 2024-10-07 05:45:11

为iframe添加onclick事件的相关文章

给网页中的元素添加onclick事件(引自锋利的jQuery)

<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta name="generator" content="editplus" /> <title>给网页中的元素添加onclick事件</p></title> <script src="jquery-1.7.1

利用事件的冒泡特性,为子标签添加Onclick事件

<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <script type="text/javascript

HTML中在a标签中添加onclick事件

1.链接的onclick 事件被先执行,其次是href属性下的动作; 2.假设链接中同时存在href 与onclick,如果想让href 属性下的动作不执行,onclick 必须得到一个false的返回值; 3.如果页面过长有滚动条,且希望通过链接的 onclick 事件执行操作.应将它的 href 属性设为 javascript:void(0);,而不要是 #,这可以防止不必要的页面跳动; 4.如果在链接的 href属性中调用一个有返回值的函数,当前页面的内容将被此函数的返回值代替; 在Jav

SpannableString 来改变textView中http协议,手机号,已经你想要改变的字的颜色,以及添加onClick事件

这是我自己封的俩个类,只要调用就能使用,相当简单: package com.example.spanable_textview; import java.util.regex.Matcher; import java.util.regex.Pattern; import com.example.spanable_textview.MainActivity.spannableListener; //这个类是获取SpannableString对象,以及添加颜色,跟点击事件的 import andro

js为元素添加onclick事件

$("div.manu a:last").on('click',function(){ if (page == totalPage) { return; } page = page + 1; search(page); }); 通过on绑定click事件

动态加载下拉框列表并添加onclick事件

1.  js动态加载元素并设置属性 摘自(http://www.liangshunet.com/ca/201408/336848696.htm) <div id="parent"></div> function addElementDiv(obj) { var parent = document.getElementById(obj); //添加 div var div = document.createElement("div"); //设

JavaScript例子1-给网页中所有&lt;p&gt;元素添加onclick事件

1 <!DOCTYPE html> 2 <html> 3 4 <head> 5 <meta charset="utf-8" /> 6 <title></title> 7 <script type="text/javascript"> 8 window.onload = function() { 9 var items = document.getElementsByTagName(&

原生js遍历每一个对象,给每一个对象添加onclick事件

<script type="text/javascript"> window.onload = function () { var imgs = document.images; for (var i = 0; i < imgs.length; i++) { (function (x) { imgs[x].onclick = function () { alert(x); } })(i); } }; </script>

JQuery 动态添加onclick事件

$('#div_id').click(function(){ show(1,2,this); });