• JS如何为iframe添加onclick事件


    如果页面上有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'); }); 
    })
  • 相关阅读:
    如何导入Support v7包?以及使用Support V7下的RecyclerView
    无言是一种教育
    自己的归宿在哪里?
    如是我愿
    【九度OJ】题目1111:单词替换
    【九度OJ】题目1054:字符串内排序
    【九度OJ】题目1061:成绩排序
    【九度OJ】题目1202:排序
    Python项目:扇贝网小组查卡助手
    Ubuntu搭建Ruby on Rails环境
  • 原文地址:https://www.cnblogs.com/TBW-Superhero/p/6910490.html
Copyright © 2020-2023  润新知