 
 Data Structure Data Structure
 Networking Networking
 RDBMS RDBMS
 Operating System Operating System
 Java Java
 MS Excel MS Excel
 iOS iOS
 HTML HTML
 CSS CSS
 Android Android
 Python Python
 C Programming C Programming
 C++ C++
 C# C#
 MongoDB MongoDB
 MySQL MySQL
 Javascript Javascript
 PHP PHP
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who
How to Convert HTML Table to JSON in JavaScript?
Working with web applications often requires parsing some HTML tables to extract the content in the appropriate format, most often in JSON format which is better for storage, transfer, or API communication. One of the most popular formats used for data exchange is JSON, mainly due to its lightweight nature and ease of integration on the front and back end. This article highlights different methods for making a JSON representation of an HTML table in JavaScript.
Approaches to Convert HTML Table to JSON
- Using JavaScript's querySelector and loops.
- Using forEach with Array.from to simplify conversion.
- Using libraries (e.g., jQuery) for simplified DOM traversal.
Using querySelector and Loops
In this way, we perform data extraction from the table's rows and cells and create the necessary JSON object. This is the most flexible approach for tables of any structure.
Example Code
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
        <meta name="viewport" 
          content="width=device-width, initial-scale=1.0">
    <title>HTML Table to JSON</title>
</head>
<body>
    <table id="data-table">
        <thead>
            <tr>
                <th>ID</th>
                <th>Name</th>
                <th>Age</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>1</td>
                <td>Pankaj</td>
                <td>20</td>
            </tr>
            <tr>
                <td>2</td>
                <td>Neeraj</td>
                <td>18</td>
            </tr>
        </tbody>
    </table>
    <script>
        function tableToJson() {
            const table = document.getElementById('data-table');
            const headers = Array.from(table.querySelectorAll('thead th')).map(th => th.textContent);
            const rows = Array.from(table.querySelectorAll('tbody tr'));
            const json = rows.map(row => {
                const cells = Array.from(row.querySelectorAll('td'));
                let obj = {};
                headers.forEach((header, i) => {
                    obj[header] = cells[i].textContent;
                });
                return obj;
            });
            return json;
        }
        document.write("<br>")
        document.write(JSON.stringify(tableToJson(), null, 2));
    </script>
</body>
</html>
Output
ID	Name	Age
1	Pankaj	20
2	Neeraj	18
[ { "ID": "1", "Name": "Pankaj", "Age": "20" }, 
  { "ID": "2", "Name": "Neeraj", "Age": "18" } ]
Using Array.from and forEach
This method combines, first of all, using an Array, which more elegantly handles rows and cells and better deals with readability. The logic is the same, but instead of manual loops, the forEach method is used.
Example Code
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
        <meta name="viewport" 
          content="width=device-width, initial-scale=1.0">
    <title>HTML Table to JSON</title>
</head>
<body>
    <table id="data-table">
        <thead>
            <tr>
                <th>ID</th>
                <th>Name</th>
                <th>Age</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>1</td>
                <td>Pankaj</td>
                <td>20</td>
            </tr>
            <tr>
                <td>2</td>
                <td>Neeraj</td>
                <td>18</td>
            </tr>
        </tbody>
    </table>
    <script>
        function tableToJson() {
            const headers = Array.from(document.querySelectorAll('#data-table thead th')).map(th => th.textContent);
            const json = [];
            document.querySelectorAll('#data-table tbody tr').forEach(row => {
                const rowData = {};
                Array.from(row.children).forEach((cell, i) => {
                    rowData[headers[i]] = cell.textContent;
                });
                json.push(rowData);
            });
            return json;
        }
        document.write("<br>")
        document.write(JSON.stringify(tableToJson(), null, 2));
    </script>
</body>
</html>
Output
ID	Name	Age
1	Pankaj	20
2	Neeraj	18
[ { "ID": "1", "Name": "Pankaj", "Age": "20" }, 
  { "ID": "2", "Name": "Neeraj", "Age": "18" } ]
Using jQuery for Easier Traversal
If you're already using jQuery then you can simplify DOM selection and traversal with jQuery's methods like each() and text().
Example Code
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" 
          content="width=device-width, initial-scale=1.0">
    <title>HTML Table to JSON</title>
    <script src=
"https://code.jquery.com/jquery-3.6.0.min.js">
    </script>
</head>
<body>
    <table id="data-table">
        <thead>
            <tr>
                <th>ID</th>
                <th>Name</th>
                <th>Age</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>1</td>
                <td>Pankaj</td>
                <td>20</td>
            </tr>
            <tr>
                <td>2</td>
                <td>Neeraj</td>
                <td>18</td>
            </tr>
        </tbody>
    </table>
    <script>
        function tableToJson() {
            const headers = [];
            $('#data-table thead th').each(function() {
                headers.push($(this).text());
            });
            const json = [];
            $('#data-table tbody tr').each(function() {
                const rowData = {};
                $(this).find('td').each(function(index) {
                    rowData[headers[index]] = $(this).text();
                });
                json.push(rowData);
            });
            return json;
        }
        document.write("<br>")
        document.write(JSON.stringify(tableToJson(), null, 2));
    </script>
</body>
</html>
Output
ID	Name	Age
1	Pankaj	20
2	Neeraj	18
[ { "ID": "1", "Name": "Pankaj", "Age": "20" }, 
  { "ID": "2", "Name": "Neeraj", "Age": "18" } ]
