最新消息:Welcome to the puzzle paradise for programmers! Here, a well-designed puzzle awaits you. From code logic puzzles to algorithmic challenges, each level is closely centered on the programmer's expertise and skills. Whether you're a novice programmer or an experienced tech guru, you'll find your own challenges on this site. In the process of solving puzzles, you can not only exercise your thinking skills, but also deepen your understanding and application of programming knowledge. Come to start this puzzle journey full of wisdom and challenges, with many programmers to compete with each other and show your programming wisdom! Translated with DeepL.com (free version)

javascript - Jquery - intercept links clicked inside an iframe - Stack Overflow

matteradmin9PV0评论

I am trying to intercept links clicked on a page including those inside an iframe. This is the code that I have but it is not working. Any ideas what I need to do?

$("#container").delegate('a', 'click', function(e){ 
//do stuff
}

Container is the id of the div just inside the iframe.

Thanks in advance for any advice

I am trying to intercept links clicked on a page including those inside an iframe. This is the code that I have but it is not working. Any ideas what I need to do?

$("#container").delegate('a', 'click', function(e){ 
//do stuff
}

Container is the id of the div just inside the iframe.

Thanks in advance for any advice

Share Improve this question edited Jul 24, 2010 at 23:16 Nick Craver 631k138 gold badges1.3k silver badges1.2k bronze badges asked Apr 29, 2010 at 11:32 KaskadeKaskade 7954 gold badges14 silver badges21 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 2

You need to reach inside the <iframe> and set the delegate there, you can do it like this:

$('#myiframe').contents().find("#container").delegate('a', 'click', function(e){ 
  //do stuff
}

Edit - Mailslut makes a good points below, if the iframe isn't on the same domain (and port), you can't do anything like this. If that's the case and you want to know more about why, read about the same-origin policy there for security reasons.

Why not add the event listener inside the iframe and then call the parent / opener to notify the event.

If you the contents of the iframe is on a different domain, you won't be able to perform this as it is classed as "click-jacking", which was a big security threat.

Post a comment

comment list (0)

  1. No comments so far