Create Dynamic Tables in ASP.NET

In ASP.Net 2.0, several controls display the data retrieved from the database in tabular form using Grid View Control, list view Control, Repeater. But in some cases when there is no option to custom these default controls. At that time, a question arises – how to generate dynamic tables? How to display the data according to requirement?

You can use Literal Control to display the HTML tagged string generated using VB/C# code in ASP.Net 2.0.

To generate the table, you can use the following C# code:

 private static string GenerateTable()
        {
            // create a string type variable to generate dynamic table
            string dynTable = "";
            // start with table tag with following attributes
            dynTable = "<table cellspacing=\"0\" cellpadding=\"2\" border=\"1\">";
            // outer loop to generate table rows
            for (int tRows = 0; tRows < 5; tRows++)
            {
                //start table row
                dynTable += "<tr>";
                // inner loop to generate columns
                for (int tCols = 0; tCols < 4; tCols++)
                {
                    // create column
                    dynTable += "<td>"; dynTable += "Row: " + (tRows + 1) + " Col: " + (tCols + 1);
                    // close td column tag
                    dynTable += "</td>";
                }
                // close table row
                dynTable += "</tr>";
            }
            // close the table tag
            dynTable += "</table>";
            return dynTable;
        }

How to use

Literal1.Text = GenerateTable(); 

Above C# code will build a string having table tag, tr as a table row, td as table data/column. To display the data retrieved from the database, you can set the tRows < [No. of DataRows Retrieved] and tCols < [No. of DataColmns].

Output Result of above code:

Row: 1 Col: 1 Row: 1 Col: 2 Row: 1 Col: 3 Row: 1 Col: 4
Row: 2 Col: 1 Row: 2 Col: 2 Row: 2 Col: 3 Row: 2 Col: 4
Row: 3 Col: 1 Row: 3 Col: 2 Row: 3 Col: 3 Row: 3 Col: 4
Row: 4 Col: 1 Row: 4 Col: 2 Row: 4 Col: 3 Row: 4 Col: 4
Row: 5 Col: 1 Row: 5 Col: 2 Row: 5 Col: 3 Row: 5 Col: 4
Next Post Previous Post
No Comment
Add Comment
comment url