jQuery - How do I bind events to hidden elements that will be shown later?

Jquery

Jquery Problem Overview


I am trying to attach 'click' events to all elements of a particular class. The problem is some of the elements are on a tab that is hidden (display: none) at the time that the event is bound. (.bind()). It seems that when these elements are shown the events are no longer bound.

$('a.someClass').bind('click', function(){
  alert("test");
});

The hidden elements do not appear to have a click event bound. If I select the hidden elements:

$('a.someClass:hidden').bind('click', function(){
  alert("test");
});

It seems the click event is not bound when these elements are no longer hidden. Has anyone experienced this? Is there a way to bind and event to elements irregardless of their display property?

Thanks

Jquery Solutions


Solution 1 - Jquery

As of jQuery 1.7, the .live() method is deprecated.

You can now use the .on() method. By attaching a delegated event to an element that is viewable in the HTML when the jQuery is run.

So if a.someClass is hidden when jQuery is run, you should attach a delegated event to the body, so it will run when there is a viewable a.someClass element in the future, for example:

$('body').on('click','input.a.someClass',function(){
  alert("test");
});

Solution 2 - Jquery

edit 2 years later: As some people pointed out, the Live function is now deprecated (as you can also see at the top of the linked docs page). The right event handler name for the current version would be On. See Maxim's answer for a good example.

Original answer:
Have you tried using Live()?

.live('click',function(){/* code */});

?

version note: live has been deprecated in jQuery 1.7 and it was removed in jQuery 1.9. This answer is only correct for jQuery versions older than jQuery 1.7

Solution 3 - Jquery

Use delegate (note this is after you unhide them):

$('body').delegate('.someClass', 'click', function (evt) {
    // do something here
});

Solution 4 - Jquery

Use

$('parentelement').on('click','taget element',function(){

})

parentelement should be visible at page load

Solution 5 - Jquery

According to the jquery documentation at http://api.jquery.com/live/

> Attach a handler to the event for all elements which match the current selector, now and in the future

Here is an example of how to use it:

<!DOCTYPE html> 
<html> 
<head> 
  <style> 
  p { background:yellow; font-weight:bold; cursor:pointer;  
          padding:5px; } 
  p.over { background: #ccc; } 
  span { color:red; } 
  </style> 
  <script src="http://code.jquery.com/jquery-1.5.js"></script> 
</head> 
<body> 
  <p>Click me!</p> 
 
  <span></span> 
<script> 
    $("p").live("click", function(){ 
      $(this).after("<p>Another paragraph!</p>"); 
    }); 
</script> 
     
</body> 
</html>

Solution 6 - Jquery

Times have changed, it would now be done using ".on"

.on('click',function(){/* code */});

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionNickView Question on Stackoverflow
Solution 1 - JqueryMaxim McNairView Answer on Stackoverflow
Solution 2 - JqueryDambView Answer on Stackoverflow
Solution 3 - JqueryAdy NgomView Answer on Stackoverflow
Solution 4 - JqueryVipinView Answer on Stackoverflow
Solution 5 - Jqueryjoe_coolishView Answer on Stackoverflow
Solution 6 - Jquerydylan maxeyView Answer on Stackoverflow