我正在尝试在 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>)
答案 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>
);
};