Solved

Show and hide elements with JavaScript

Posted on 2016-10-07
8
57 Views
Last Modified: 2016-10-07
Hi Experts,
Please take a look at the attached code. My goal is to close any open row that shows the details when a different name is clicked.
Right now all colspan="3" rows can be opened simultaneously. How can the code be modified so that only one colspan="3" row can be open when a Name is clicked?
Thank you for your help.
<html>
<head>
<title>Toggle</title>
<script type="text/javascript" src="/jquery/jquery-1.8.2.min.js"></script>
<script type="text/javascript">
$(function() {
    $("td[colspan=3]").find("p").hide();
    $("table").click(function(event) {
        event.stopPropagation();
        var $target = $(event.target);
        if ( $target.closest("td").attr("colspan") > 1 ) {
            $target.slideUp();
        } else {
            $target.closest("tr").next().find("p").slideToggle();
        }                    
    });
});
</script>
</head>
<body>

Click on a row for more info:
<table border ="1">
    <tr><td><p>Name</p></td><td><p>Age</p></td><td><p>Info</p></td></tr>
    <tr><td colspan="3"><p>First Person Details</p>
    </td></tr>

    <tr><td><p>Name</p></td><td><p>Age</p></td><td><p>Info</p></td></tr>
    <tr><td colspan="3"><p>Second Person Details</p>
    </td></tr>
    
    <tr><td><p>Name</p></td><td><p>Age</p></td><td><p>Info</p></td></tr>
    <tr><td colspan="3"><p>Third Person Details</p>
    </td></tr>    
</table>

</body>
</html>

Open in new window

0
Comment
Question by:romsom
  • 3
  • 2
  • 2
8 Comments
 
LVL 22

Expert Comment

by:Kim Walker
ID: 41833974
colspan=3 is a column not a row. And it is pointless to use colspan=3 when that field in every row is colspan=3. colspan is like merging cells in Excel. It means that this cell should span the width of 3 cells in another row in this table. Perhaps you have another row that makes this useful though.

Are you wanting to hide just the colspan=3 cells and leave the other cells on that row visible. Otherwise, how would you click on the name if the whole row is hidden?

You cannot hide a table cell (<td>) without disrupting your table structure. However, since you've used <p> tags within your table, you could hide the <p> elements within those cells. This would be much easier in jQuery. Are you able to use jQuery?
0
 

Author Comment

by:romsom
ID: 41833986
Yes, I'm using jQuery.
I would like to hide the entire row that contains the Person Details when a different Name is clicked.
0
 
LVL 56

Accepted Solution

by:
Julian Hansen earned 500 total points
ID: 41833988
Try this
$(function() {
  $('tr:odd p').hide();
  $('tr:even').click(function() {
    $('tr:odd p').hide();
    $(this).next().find('p').slideToggle();
  });
});

Open in new window

1
MIM Survival Guide for Service Desk Managers

Major incidents can send mastered service desk processes into disorder. Systems and tools produce the data needed to resolve these incidents, but your challenge is getting that information to the right people fast. Check out the Survival Guide and begin bringing order to chaos.

 
LVL 22

Expert Comment

by:Kim Walker
ID: 41833997
I guess I need to slow down. I read those as three long rows of cells instead of 6 short rows. On my screen the first row ran the full width of the box so I thought it just word wrapped to the next line. I should know that code doesn't word wrap.

Anyway, Julian has provided the code you need.
0
 
LVL 56

Expert Comment

by:Julian Hansen
ID: 41833998
Slight improvement - fixes problem of slideToggle on open item if clicked
$(function() {
  $('tr:odd p').hide();
  $('tr:even').click(function() {
    if (!$(this).next().find('p').is(':visible')) {
      $('tr:odd p').hide();
    }
    $(this).next().find('p').slideToggle();
  });
});

Open in new window

0
 

Author Closing Comment

by:romsom
ID: 41834005
Thank you very much, it's perfect.
0
 
LVL 56

Expert Comment

by:Julian Hansen
ID: 41834091
You are welcome.
0

Featured Post

Guide to Performance: Optimization & Monitoring

Nowadays, monitoring is a mixture of tools, systems, and codes—making it a very complex process. And with this complexity, comes variables for failure. Get DZone’s new Guide to Performance to learn how to proactively find these variables and solve them before a disruption occurs.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Introduction Got endorsements from your clients?  Great!  There is almost nothing better than word-of-mouth advertising.  But how can you do that on the internet?  Sure you can make a page for endorsement quotations and list them all, but who is …
Today, the web development industry is booming, and many people consider it to be their vocation. The question you may be asking yourself is – how do I become a web developer?
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

756 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question