如何将<Link> react-router添加到Material-Table?

时间:2019-11-05 00:45:15

标签: reactjs material-table

我正在使用的材料表库是基于Material-UI表的数据表。

数据表具有可编辑的属性,并在同一表中添加了一条新记录,但我不想在同一表中这样做。

我需要使用一个按钮,因为我希望它打开一个材质UI菜单。但是,我不知道如何添加链接或类似内容。

我尝试使用以下代码段进行了尝试,但它告诉我即使很重要也未定义Link

import React, { useState, useEffect } from 'react';
import MaterialTable from 'material-table';
import EditIcon from '@material-ui/icons/Edit';
import { IconButton } from '@material-ui/core';
import  axios  from 'axios';
import { Link} from 'react-router-dom';

export default function TableProducts() {

const url='/api/products';

const [product, setProduct]= useState({Products:[]});


 useEffect(()=>{
    const getProduct=async()=>{
            const response =await axios.get(url);
            setProduct(response.data);
    }
    getProduct();
},[]);

  return (

<MaterialTable
      title="Products"
      columns={[
        {title: 'id',field: 'id', type: 'numeric', hidden:'false'},
        { title: 'nameproduct',field: 'nameproduct', },
        { title: 'description', field: 'description' },
        { title: 'price', field: 'price' },
      ]} 
      data={product.Products}
      options={{
        filtering: true,
        sorting: true
      }}
      actions={[
        {
          icon: 'edit',
          tooltip: 'Edit ',
          onClick: () => 
            <Link to={`/product/${data._id}/edit`}>Edit</Link> 

        }
      ]}
      />

    );
  }

我想完成这样的事情

                <Link
                    to={`/product/edit/${product.id}`}
                    className="btn btn-success mr-2">Editar
                </Link>

3 个答案:

答案 0 :(得分:1)

代替这个

actions={[
        {
          icon: 'edit',
          tooltip: 'Edit ',
          onClick: () => 
            <Link to={`/product/${data._id}/edit`}>Edit</Link> 

        }
      ]}

这样做

actions={[
    rowData => ({
      icon: () => <Link to={`/product/${rowData._id}/edit`}>Edit(Replace with icon code)</Link>
      tooltip: 'Edit ',
      onClick: (rowData)
    })
  ]}

欲了解更多信息,请访问 https://material-table.com/#/docs/features/actions

答案 1 :(得分:0)

您是否将其嵌套在路由器组件中?

<Router>
<MaterialTable ...>
  <div>
    <nav>
      <ul>
        <li>
          <Link to="/">Home</Link>
        </li>
        <li>
          <Link to="/about">About</Link>
        </li>
        <li>
          <Link to="/users">Users</Link>
        </li>
      </ul>
    </nav>
   </div>
   </MaterialTable>
  </Router>

添加了有关合并材料表的部分。只需尝试将路由器设置为根容器即可。

答案 2 :(得分:0)

actions={[
    icon: () => <Link to='/test'><Icon /></Link>,
    tooltip: 'tip',
    onClick: (event, rowData) => 
        localStorage.setItem('selectedRowData', rowData)
    ]}

链接到='/ test'->要通过单击操作打开的所需根目录

图标->可用于导入和放置的操作图标

onClick-> 在Onclick事件中,将要获取的信息保存到所需的根目录

提示:请记住,如果数据量较大,最好使用redux