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

Related Questions

ASP.Net has a tag called CheckboxList. The output of this tag looks like this:
IIS7, WINDOWS WEB SERVER 2008, ASP.NET 4.0 Does the output cache work when using
when asp.net output a page ,I want to add some same parameters for all
What are the alternative solutions to Output Cache in asp.net MVC3? I don't know
I'm trying to prevent output cached page from being ejected from my asp.net output
The ASP.NET WebForms trace output has a section for Application State. Is it possible
I am already using output caching in my ASP.NET MVC application. Page speed tells
I am creating a web api using asp.net mvc4 and the response output is
I use troygoode's PagedList to output paginated links in my ASP.NET MVC application http://nuget.org/packages/PagedList.Mvc
Is it possible to clear the output cache of one asp.net web application from

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.