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>
    

      

    喜欢的朋友请帮忙点个赞!!!
  • 相关阅读:
    Java 课程设计:LWZ
    回溯法解骑士巡游问题
    2021.3.30 错误2
    2021.3.29 关于上下滚动
    2021.3.28 WebView的用法
    2021.3.27 关于错误1
    2021.3.26 Python创建表
    2021.3.25 人月神话阅读笔记06
    2021.3.24 个人作业第三阶段1
    2021.3.23 个人作业第三阶段
  • 原文地址:https://www.cnblogs.com/mchuang/p/5178235.html
Copyright © 2011-2022 走看看