javascript - issue in adding events to dynamically coming elements -


doing accordion, structure follows, few divs coming dynamically, not working.

parent div

<div id="resultarea" class="accordion">   </div> 

inside parent tag following tags coming dynamically.

<div class="accordion-item">     item 1 <div class="type"></div> </div> <div class="data">    data related item 1 </div> <div class="accordion-item">     item 2 <div class="type"></div>  </div> <div class="data">        data related item 2 </div> 

below javascript

$(function($) {       var allaccordions = $('.accordion div.data');       var allaccordionitems = $('.accordion .accordion-item');       $('.accordion > .accordion-item').click(function() {         if($(this).hasclass('open'))         {           $(this).removeclass('open');           $(this).next().slideup("slow");         }         else         {         allaccordions.slideup("slow");         allaccordionitems.removeclass('open');         $(this).addclass('open');         $(this).next().slidedown("slow");         return false;         }       }); }); 

but not working when items data coming dynamically, if static page working. please me solve

static 1 in jsfiddle find below

http://jsfiddle.net/ea6xx/

try use event-delegation on dynamically created elements,

$('.accordion').on('click','.accordion > .accordion-item',function() { 

full code:

$('.accordion').on('click','.accordion > .accordion-item',function() {    if($(this).hasclass('open'))    {      $(this).removeclass('open');      $(this).next().slideup("slow");    }   else   {     allaccordions.slideup("slow");     allaccordionitems.removeclass('open');     $(this).addclass('open');     $(this).next().slidedown("slow");     return false;   } }); 

Comments

Popular posts from this blog

C# random value from dictionary and tuple -

cgi - How do I interpret URLs without extension as files rather than missing directories in nginx? -

.htaccess - htaccess convert request to clean url and add slash at the end of the url -