zoukankan      html  css  js  c++  java
  • 为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>
    

      

    喜欢的朋友请帮忙点个赞!!!
  • 相关阅读:
    HDOJ 1241 Oil Deposits【最大连通块 dfs】
    POJ 3984 迷宫问题【迷宫最短路径 bfs】
    封装
    继承的另一种使用方式。。。
    类的绑定方法与继承
    XML模块与类的定义
    常用模块三
    python day19
    常用模块与项目目录规范
    python day17
  • 原文地址:https://www.cnblogs.com/mchuang/p/5178235.html
Copyright © 2011-2022 走看看