Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 180937
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 11, 20262026-05-11T14:40:25+00:00 2026-05-11T14:40:25+00:00

The output of the asp.net datagrid doesn’t include the thead and tbody elements required

  • 0

The output of the asp.net datagrid doesn’t include the thead and tbody elements required for the jquery tablesorter to work.

E.g. it looks like this:

    <table>         <tr>this is my header row</tr>         <tr>content row 1</tr>         <tr>content row 2</tr>         <tr>content row 3</tr>         ...         <tr>content row n</tr>     </table> 

and it needs to look like this:

    <table>         <thead>             <tr>this is my header row</tr>         </thead>         <tbody>             <tr>content row 1</tr>             <tr>content row 2</tr>             <tr>content row 3</tr>             ...             <tr>content row n</tr>         </tbody>     </table> 

I knocked up the following javascript to dynamically insert them, but the table is still not sortable. I’ve confirmed that if I manually insert the thead and tbody tags directly into the output html, the table is sortable, but when I try to do it using the DOM, it doesn’t seem to work.

What am I missing?

    $(document).ready(function()          {              var tbl = document.getElementById('mytableid');              // new header and body elements to be inserted             var tblHead = document.createElement('thead');             var tblBody = document.createElement('tbody');             // get the first row and the remainder             var headerRow = $(tbl).find('tr:first')             var bodyRows  = $(tbl).find('tr:not(:first)');              // remove the original rows             headerRow.remove();             bodyRows.remove();              // add the rows to the header and body respectively             $(tblHead).append(headerRow);             $(tblBody).append(bodyRows);              // add the head and body into the table             $(tbl).append(tblHead);             $(tbl).append(tblBody);              // apply the tablesorter             $(tbl).tablesorter();          }      );  

EDIT: I actually solved the problem before I posted the question, but I thought I’d go ahead and post it anyway, as it may be useful to others… See my answer below.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-11T14:40:26+00:00Added an answer on May 11, 2026 at 2:40 pm

    Apparently, a phantom <tbody> element appears in the output. The trick is to ensure that it is removed before adding in the generated ones… Hopefully this will be useful to someone!

        $(document).ready(function()          {              var tbl = document.getElementById('mytableid');              // new header and body elements to be inserted             var tblHead = document.createElement('thead');             var tblBody = document.createElement('tbody');             // get the first row and the remainder             var headerRow = $(tbl).find('tr:first')             var bodyRows  = $(tbl).find('tr:not(:first)');              // remove the original rows             headerRow.remove();             bodyRows.remove();              // SOLUTION HERE:              // remove any existing thead/tbody elements             $(tbl).find('tbody').remove();             $(tbl).find('thead').remove();              // add the rows to the header and body respectively             $(tblHead).append(headerRow);             $(tblBody).append(bodyRows);              // add the head and body into the table             $(tbl).append(tblHead);             $(tbl).append(tblBody);              // apply the tablesorter             $(tbl).tablesorter();          }      );  
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 83k
  • Answers 83k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • Editorial Team
    Editorial Team added an answer A new option has popped up on the scene from… May 11, 2026 at 4:46 pm
  • Editorial Team
    Editorial Team added an answer For the auto-login to the .net app (assuming it's ASP.net)… May 11, 2026 at 4:46 pm
  • Editorial Team
    Editorial Team added an answer <!--#if expr="$SERVER_PORT = 80" --> <!--#set var="protocol" value="http" --> <!--#elif… May 11, 2026 at 4:46 pm

Related Questions

The output of the asp.net datagrid doesn't include the thead and tbody elements required
This is a very basic question. I'm just on my mission to learn ASP.NET
I was looking for something like Server.MapPath in the ASP.NET realm to convert the
I've asked a few questions on this topic before. Before we're able to implement
In the Render method of an ASP.NET web-control, I need to alter the output

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.