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'); }); 
})

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM