博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS如何为iframe添加onclick事件
阅读量:6041 次
发布时间:2019-06-20

本文共 1731 字,大约阅读时间需要 5 分钟。

 

如果页面上有iframe时,鼠标点击在iframe内时,包含iframe的document是不响应任何事件的,

例如:

 $("#iframe1").click(function(){//点击iframe

            alert("点击1");
 });
或者     
 $(function(){//给iframe循环绑定click事件
            for(var n=1;n<=7;n++){
                $("#iframe"+n).bind("click",{n:n}, clickHandler);
            }
            function clickHandler(event) {
                var n = event.data.n;
                alert("点击"+n);
            }
 });

均行不通。

所以需要给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;                  }              }          }      }  };

调用方法:

//页面加载添加$(document).ready(function(){    IframeOnClick.track(document.getElementById("iFrame"), function() { alert('a click'); }); })

 

转载于:https://www.cnblogs.com/TBW-Superhero/p/6910490.html

你可能感兴趣的文章
[Java开发之路](14)反射机制
查看>>
mac gentoo-prefix安装git svn
查看>>
浅尝异步IO
查看>>
C - Train Problem II——(HDU 1023 Catalan 数)
查看>>
Speak loudly
查看>>
iOS-在项目中引入RSA算法
查看>>
[译] 听说你想学 React.js ?
查看>>
gulp压缩合并js与css
查看>>
块级、内联、内联块级
查看>>
Predicate
查看>>
[面试题记录01]实现一个function sum达到一下目的
查看>>
这个季节的忧伤,点到为止
查看>>
mysql通过配置文件进行优化
查看>>
省级网站群建设关注点
查看>>
工作第四天之采集资源
查看>>
innobackupex 在增量的基础上增量备份
查看>>
Windows Server 2012 R2 DirectAccess功能测试(2)App1服务器安装及配置
查看>>
基于清单的启动器的实现
查看>>
外网用户通过citrix打印慢的解决方法
查看>>
STL容器的使用
查看>>