正在寻找将"导出到CSV"按钮添加到react表格的方法,该表格是npmjs包(https://www.npmjs.com/package/react-table).

我需要添加一个自定义按钮,用于将表格数据导出到csv或xls格式的excel工作表?

推荐答案

下面是整合的样子

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;

这也适用于过滤器.

Reactjs相关问答推荐

Reaction-路由v6动态路径RegExp

有没有办法在Shopify中显示自定义计算的交货日期?

我应该如何管理设置组件初始状态的复杂逻辑?

React Context未正确更新

找不到名称setCometChat

如果我使用 formik,如何在嵌套对象中写入正确的值?

如何根据ReactJS中元素列表中的布尔值仅显示一次值

React Wordpress Apache 在索引之外重新加载 -> 未找到页面

React Native - 如何处理错误带有有效负载的NAVIGATE操作..未被任何导航器处理?

在一个事件处理程序中进行多次调度是个好主意吗?

对于 ref 上的可见 prop 或 open 方法来react 组件,哪种方式更好?

Next.js 和理智 | npm run build 时预渲染页面/时发生错误

无法读取未定义的属性(读取值)...TypeError:无法读取未定义的属性(读取值)

从 React 应用程序调用未经身份验证的 graphql 查询时出现错误:没有当前用户

更新 Next.js 路由查询更改的状态会导致无限循环

ReactJS:useMemo 钩子修复了我的无限重新渲染问题而不是 useEffect

渲染的钩子比预期的少.这可能是由 React Hooks 中意外的提前返回语句引起的

如何在 react-router-dom v6 中实现监听功能?

哪个 PrivateRouter 实现更好:高阶组件还是替换?

useEffect 仅在跟随链接后有效,不适用于直接链接