2

我有以下问题:当我在 deleteRows 函数中打印 shells 变量的值时,它会打印一个空对象,但是当我在外面打印它(第一个 console.log)时,它会正确打印数组。这是关于什么的?我通过删除一个值来调用该函数。

我尝试制作箭头函数,如您在代码中看到的那样。


import React from 'react';
// import PropTypes from 'prop-types';  //verrificacion de tipos
import MUIDataTable from 'mui-datatables';
import columns from '../Objects/columns';

const axios = require('axios');

function SimpleTable(props) {
  const { datos } = props;
  const shells = datos.map(
    dato => Object.values(dato),
  );
  console.log({shells})

  const deleteRows = (RowsDeleted) => {
    const ids = RowsDeleted.data.map(d => d.dataIndex);
    // const idsToDeleted = ids.map(d => shells[d][9]);
    console.log({shells})
    axios({
      method: 'post',
      url: 'http://localhost:5000/eliminado',
      data: RowsDeleted,
    });
  }

  const options = {
    filterType: 'dropdawn',
    responsive: 'stacked',
    onRowsDelete: deleteRows,

  };

  // console.log(shells)
  return (

    <MUIDataTable
      title="NutsForShells"
      data={shells}
      columns={columns}
      options={options}
    />
  );
}

// SimpleTable.propTypes = {
//   classes: PropTypes.object.isRequired,
// };

export default (SimpleTable);

4

1 回答 1

2

通过这次对话我发现,我们不能使用来自外部callback的数据mui-datatables

文档中,

onRowsDelete - 删除行时触发的回调函数。function(rowsDeleted: object(lookup: {dataindex: boolean}, data: arrayOfObjects: {index, dataIndex})) => void OR false (返回 false 防止行删除。)

当您单击删除行时,您将获得要删除的行以及完整的数据数组。所以你的deleteRows函数应该接受第二个参数,它是一个数据数组,

const deleteRows = (RowsDeleted, data) => {
    const ids = RowsDeleted.data.map(d => d.dataIndex);
    // const idsToDeleted = ids.map(d => shells[d][9]);   //This is possibly this, ids.map(d => data[d][9]) 
    console.log(data)  //Now you will get data
    axios({
      method: 'post',
      url: 'http://localhost:5000/eliminado',
      data: RowsDeleted,
    });
  }
于 2019-08-05T03:40:39.533 回答