Reactjs 物料表选择行导出
我有一个react应用程序,它保存一个填充了数据的物料表,我一直在尝试允许用户选择要导出到csv的特定行。我也在这个[链接][1]上发布了澄清,以获得更多的指导。这是我得到的一些样本数据Reactjs 物料表选择行导出,reactjs,material-table,Reactjs,Material Table,我有一个react应用程序,它保存一个填充了数据的物料表,我一直在尝试允许用户选择要导出到csv的特定行。我也在这个[链接][1]上发布了澄清,以获得更多的指导。这是我得到的一些样本数据 import React, { useState, useEffect } from "react"; import "../../App.css"; import { forwardRef } from "react"; import Avatar
import React, { useState, useEffect } from "react";
import "../../App.css";
import { forwardRef } from "react";
import Avatar from "react-avatar";
import Grid from "@material-ui/core/Grid";
import CsvBuilder from "csv-builder";
import MaterialTable from "material-table";
import AddBox from "@material-ui/icons/AddBox";
import ArrowDownward from "@material-ui/icons/ArrowDownward";
import Check from "@material-ui/icons/Check";
import ChevronLeft from "@material-ui/icons/ChevronLeft";
import ChevronRight from "@material-ui/icons/ChevronRight";
import Clear from "@material-ui/icons/Clear";
import DeleteOutline from "@material-ui/icons/DeleteOutline";
import Edit from "@material-ui/icons/Edit";
import FilterList from "@material-ui/icons/FilterList";
import FirstPage from "@material-ui/icons/FirstPage";
import LastPage from "@material-ui/icons/LastPage";
import Remove from "@material-ui/icons/Remove";
import SaveAlt from "@material-ui/icons/SaveAlt";
import Search from "@material-ui/icons/Search";
import ViewColumn from "@material-ui/icons/ViewColumn";
import axios from "axios";
const tableIcons = {
Add: forwardRef((props, ref) => <AddBox {...props} ref={ref} />),
Check: forwardRef((props, ref) => <Check {...props} ref={ref} />),
Clear: forwardRef((props, ref) => <Clear {...props} ref={ref} />),
Delete: forwardRef((props, ref) => <DeleteOutline {...props} ref={ref} />),
DetailPanel: forwardRef((props, ref) => (
<ChevronRight {...props} ref={ref} />
)),
Edit: forwardRef((props, ref) => <Edit {...props} ref={ref} />),
Export: forwardRef((props, ref) => <SaveAlt {...props} ref={ref} />),
Filter: forwardRef((props, ref) => <FilterList {...props} ref={ref} />),
FirstPage: forwardRef((props, ref) => <FirstPage {...props} ref={ref} />),
LastPage: forwardRef((props, ref) => <LastPage {...props} ref={ref} />),
NextPage: forwardRef((props, ref) => <ChevronRight {...props} ref={ref} />),
PreviousPage: forwardRef((props, ref) => (
<ChevronLeft {...props} ref={ref} />
)),
ResetSearch: forwardRef((props, ref) => <Clear {...props} ref={ref} />),
Search: forwardRef((props, ref) => <Search {...props} ref={ref} />),
SortArrow: forwardRef((props, ref) => (
<ArrowDownward {...props} ref={ref} />
)),
ThirdStateCheck: forwardRef((props, ref) => (
<Remove {...props} ref={ref} />
)),
ViewColumn: forwardRef((props, ref) => <ViewColumn {...props} ref={ref} />),
};
//api that the data is manipulated from
const api = axios.create({
baseURL: `https://reqres.in/api/users?page=2`,
});
function DisplayTableSanitized() {
var COLUMNS = [
{
title: "Icon",
render: (rowData) => (
<Avatar
maxInitials={1}
size={40}
round={true}
src={rowData.avatar}
/>
),
},
{ title: "First Name", field: "first_name" },
{ title: "Last Name", field: "last_name" },
{ title: "Email", field: "email" },
];
//table data
const [data, setData] = useState([]);
const [columns, setColumns] = useState(COLUMNS);
useEffect(() => {
api.get("")
.then((res) => {
setData(res.data.data);
})
.catch((error) => {
console.log("Error");
console.log(error.data.data);
});
}, []);
return (
<div className="DisplayTable" style={{ marginTop: "5vh" }}>
<Grid container spacing={1}>
<Grid item xs={1}></Grid>
<Grid item xs={10}>
<MaterialTable
title="TestDate_Table"
columns={columns}
data={data}
icons={tableIcons}
options={{
selection: true,
exportButton: true,
emptyRowsWhenPaging: false,
pageSize: 5,
pageSizeOptions: [5, 10, 25, 50, 100, 200],
overflowX: "hidden",
overflowY: "auto",
}}
actions={[
{
position: "toolbarOnSelect",
icon: SaveAlt,
tooltip: "Export the selected rows!",
onClick: (e, rowData) => {
const fileName = "TestDate_Table";
const builder = new CsvBuilder(
fileName + ".csv"
);
builder
.setColumns(
columns.map(
(columnDef) => columnDef.title
)
)
.addRows(
rowData.map((rowData) =>
columns.map(
(columnDef) =>
rowData[columnDef.field]
)
)
)
.exportFile();
},
},
]}
/>
</Grid>
<Grid item xs={1}></Grid>
</Grid>
</div>
);
}
export default DisplayTableSanitized;
import React,{useState,useffect}来自“React”;
导入“../../App.css”;
从“react”导入{forwardRef};
从“反应化身”导入化身;
从“@material ui/core/Grid”导入网格;
从“csv生成器”导入CsvBuilder;
从“物料表”中导入物料表;
从“@material ui/icons/AddBox”导入AddBox;
从“@material ui/icons/arrowdown”向下导入箭头;
从“@物料界面/图标/检查”导入检查;
从“@material ui/icons/ChevronLeft”导入ChevronLeft;
从“@material ui/icons/ChevronRight”导入ChevronRight;
从“@material ui/icons/Clear”导入清除;
从“@material ui/icons/DeleteOutline”导入DeleteOutline;
从“@material ui/icons/Edit”导入编辑;
从“@material ui/icons/FilterList”导入过滤器列表;
从“@material ui/icons/FirstPage”导入第一页;
从“@material ui/icons/LastPage”导入LastPage;
从“@material ui/icons/Remove”导入删除;
从“@material ui/icons/SaveAlt”导入SaveAlt;
从“@material ui/icons/Search”导入搜索;
从“@material ui/icons/ViewColumn”导入ViewColumn;
从“axios”导入axios;
常数表图标={
Add:forwardRef((props,ref)=>事实证明,上面的工作非常完美。我刚刚使用了错误的模块
import { CsvBuilder } from "filefy";
是您真正想要的导入