Экспорт в CSV-кнопку в таблице реакции
Ищите способ добавить кнопку "Экспорт в CSV" в таблицу реакции, которая является пакетом npmjs (https://www.npmjs.com/package/react-table).
Мне нужно добавить пользовательскую кнопку для экспорта данных таблицы в лист Excel в формате CSV или XLS?
Ответы
Ответ 1
Взгляните на эту библиотеку npm - https://www.npmjs.com/package/react-csv
Например -
import {CSVLink, CSVDownload} from 'react-csv';
const csvData =[
['firstname', 'lastname', 'email'] ,
['John', 'Doe' , '[email protected]'] ,
['Jane', 'Doe' , '[email protected]']
];
<CSVLink data={csvData} >Download me</CSVLink>
// or
<CSVDownload data={csvData} target="_blank" />
Ответ 2
Хотя принятый ответ является правильным, но для обеспечения беспроблемной интеграции потребовалось больше работы. Вот как будет выглядеть интеграция
import React from 'react';
import 'react-dropdown/style.css'
import 'react-table/react-table.css'
import ReactTable from "react-table";
import {CSVLink} from "react-csv";
const columns = [
{
Header: 'name',
accessor: 'name', // String-based value accessors!
},
{
Header: 'age',
accessor: 'age',
}]
class AllPostPage extends React.Component {
constructor(props) {
super(props);
this.download = this.download.bind(this);
this.state = {
tableproperties: {
allData: [
{"name": "ramesh","age": "12"},
{"name": "bill","age": "13"},
{"name": "arun","age": "9"},
{"name": "kathy","age": "21"}
]
},
dataToDownload: []
};
}
download(event) {
const currentRecords = this.reactTable.getResolvedState().sortedData;
var data_to_download = []
for (var index = 0; index < currentRecords.length; index++) {
let record_to_download = {}
for(var colIndex = 0; colIndex < columns.length ; colIndex ++) {
record_to_download[columns[colIndex].Header] = currentRecords[index][columns[colIndex].accessor]
}
data_to_download.push(record_to_download)
}
this.setState({ dataToDownload: data_to_download }, () => {
// click the CSVLink component to trigger the CSV download
this.csvLink.link.click()
})
}
render() {
return <div>
<div>
<button onClick={this.download}>
Download
</button>
</div>
<div>
<CSVLink
data={this.state.dataToDownload}
filename="data.csv"
className="hidden"
ref={(r) => this.csvLink = r}
target="_blank"/>
</div>
<div>
<ReactTable ref={(r) => this.reactTable = r}
data={this.state.tableproperties.allData} columns={columns} filterable
defaultFilterMethod={(filter, row) =>
String(row[filter.id]).toLowerCase().includes(filter.value.toLowerCase())}
/>
</div>
</div>
}
}
export default AllPostPage;
Это будет работать и с фильтрами.
Ответ 3
Я подумал, что могу воспользоваться чрезвычайно ценным ответом наилучших пожеланий с упрощенной реализацией download
.
export = e => {
const currentRecords = this.ReactTable.getResolvedState().sortedData;
this.setState({ dataToDownload: this.dataToDownload(currentRecords, columns) }, () =>
this.csvLink.link.click()
);
}
dataToDownload = (data, columns) =>
data.map(record =>
columns.reduce((recordToDownload, column) => {
recordToDownload[column.Header] = record[column.accessor];
return recordToDownload;
}, {})
);
Я использовал это, чтобы разрешить экспорт нескольких таблиц в один компонент, добавив дополнительные функции export
.