反应:未捕获的类型错误:X 不是函数

时间:2021-03-05 02:23:21

标签: javascript reactjs react-table

我正在尝试在 react-table 列中呈现一个按钮。如果我将按钮重构为它自己的组件,它会抱怨 it's not a function

顶级(ExampleReactTable.js):

const handleClick = () => setIsOpen(true);

const columns = getTableColumns(handleClick);

中间层(getTableColumns.js):

Cell: () => <ExampleButton handleClick={() => handleClick()} />

底部层(ExampleButton.js):

const ExampleButton = handleClick => {
  console.log(handleClick);
  return (
    <Box>
      <Button variation="text" onClick={() => handleClick()}>
        Click
      </Button>
    </Box>
  );
};

此错误为 handleClick is not a function

如果我不重构按钮,它会起作用:

Cell: () => (
        <Box>
          <Button variation="text" onClick={() => handleClick()}>
            Click
          </Button>
        </Box>)

1 个答案:

答案 0 :(得分:1)

你没有解构道具,因为函数接收道具作为一个对象,你作为一个函数传递给onclick,导致错误,试试这个:

const ExampleButton = ({handleClick}) => {
  console.log(handleClick);
  return (
    <Box>
      <Button variation="text" onClick={() => handleClick()}>
        Click
      </Button>
    </Box>
  );
};

这与:

const ExampleButton = (props) => {
  console.log(handleClick);
  return (
    <Box>
      <Button variation="text" onClick={() => props.handleClick()}>
        Click
      </Button>
    </Box>
  );
};