从父框架触发iframe内的元素上的事件处理程序

时间:2012-08-20 03:48:34

标签: jquery iframe event-handling

我有一个HTML页面。在其中我使用jQuery在链接上附加click事件。然后我使用iframe从另一个页面引用这个html页面。但是我无法触发与js链接的事件(当我用鼠标点击链接时,事件被触发没有问题)。如何从父框架触发该事件?我尝试了以下但它不起作用:

var frame = $('#mainFrame'); // the iframe I am trying to access
var link = $('a.btn', frame.contents()); // the element is found correctly
link.trigger('click');  // nothing happens. 
var e = link.data('events');  // e is undefined. 

2 个答案:

答案 0 :(得分:12)

以下是如何做到这一点。

document.getElementById('ifrmMsg').contentWindow.$('a:first').trigger('click');

您也可以使用postMessage()来实现此目的。它也可以用于跨域。但是,iframe中的JS必须监听message事件,即您需要控制iframe的来源。

答案 1 :(得分:1)

只需在iframe标记内放置onload()事件。

<iframe src="http://myURL.com" onload="myFunction()">