Okay, so you’ve got two options here :
Use jQuery UI’s accordion – its nice, easy and fast. See more info here
Or, if you still wanna do this by yourself, you could remove the fieldset (its not semantically right to use it for this anyway) and create a structure by yourself.
Here’s how you do that. Create a HTML structure like this :
- This is just some random content.
- This is just some random content.
- This is just some random content.
- This is just some random content.
With this CSS: (This is to hide the .content stuff when the page loads.
.container .content {
display: none;
padding : 5px;
}
Then, using jQuery, write a click event for the header.
$(“.header”).click(function () {
$header = $(this);
//getting the next element
$content = $header.next();
//open up the content needed – toggle the slide- if visible, slide up, if not slidedown.
$content.slideToggle(500, function () {
//execute this after slideToggle is done
//change text of header based on visibility of content div
$header.text(function () {
//change text based on condition
return $content.is(“:visible”) ? “Collapse” : “Expand”;
});
});
});
Here’s a demo : http://jsfiddle.net/hungerpain/eK8X5/7/
how about:
jQuery:
$(‘.majorpoints’).click(function(){
$(this).find(‘.hider’).toggle();
});
HTML
Fiddle
This way you are binding the click event to the .majorpoints class an you don’t have to write it in the HTML each time.