Home Reactjs How to Export table to a XLSX file in React?

How to Export table to a XLSX file in React?

by therichpost
0 comments
HOW TO EXPORT TABLE TO A XLSX FILE IN REACT?

Exporting a table to an XLSX file in a React application can be done using third-party libraries that handle Excel file creation and management. A popular choice for this is xlsx from SheetJS, which allows for manipulation of Excel files. Here’s a basic guide on how to implement this functionality:

For reactjs new comers, please check the below link:

1. Install the Necessary Libraries

First, you’ll need to install xlsx. You can add it to your React project via npm or yarn:

npm install xlsx

or

yarn add xlsx

2. Create a Component to Export the Table

Next, create a React component or function that triggers the export. Here’s a simple example where data is hardcoded, but in a real-world scenario, you would likely pass the data to the export function dynamically (e.g., via props or state).

Example Component:

import React from 'react';
import * as XLSX from 'xlsx';

function ExportToExcel() {
    const data = [
        { name: "John Doe", email: "john@example.com", age: 28 },
        { name: "Jane Doe", email: "jane@example.com", age: 34 },
        { name: "Jim Beam", email: "jim@example.com", age: 46 }
    ];

    const handleExport = () => {
        // Create a new workbook
        const wb = XLSX.utils.book_new();
        // Convert data to worksheet
        const ws = XLSX.utils.json_to_sheet(data);
        // Append worksheet to workbook under the name "Sheet1"
        XLSX.utils.book_append_sheet(wb, ws, "Sheet1");
        // Write workbook and trigger download
        XLSX.writeFile(wb, "Data.xlsx");
    };

    return (
        <button onClick={handleExport}>Export to Excel</button>
    );
}

export default ExportToExcel;

Explanation:

  • Data Definition: The data array contains objects that represent the rows you want to export. Each object’s keys should match the desired column headers in the Excel file.
  • Workbook Creation: A new workbook is created using XLSX.utils.book_new().
  • Data Conversion: The data array is converted into a worksheet using XLSX.utils.json_to_sheet(data).
  • Appending Worksheet: The newly created worksheet is then appended to the workbook.
  • Export: XLSX.writeFile() is used to generate the Excel file and prompt the user to save it locally.

3. Integrate the Export Component

Finally, use the ExportToExcel component wherever you need the export functionality in your app:

import React from 'react';
import ExportToExcel from './ExportToExcel';

function App() {
    return (
        <div>
            <h1>My Data Table</h1>
            <ExportToExcel />
        </div>
    );
}

export default App;

This simple example sets up the basics. Depending on your needs, you might want to extend this by dynamically generating the data from state, handling more complex data structures, or customizing the file’s formatting and styles using xlsx options.

Jassa

Thanks

You may also like

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.