作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在 UseEffect 中调用一个 prop 函数。以下代码有效:
useEffect(() => {
props.handleClick(id);
}, [id]);
props
不是依赖。
useEffect(() => {
props.handleClick(id);
}, [id, props]);
const ParentGrid = ({rows, columns}) => {
const [selection, setSelection] = useState(null);
const handleClick = selectedRows => {
setSelection(selectedRows.map(i => rows[i]));
};
return (
<ChildGrid
columns={columns}
data={data}
handleClick={handleClick}
/>
const ChildGrid = props => {
const {data, handleClick, ...rest} = props;
useEffect(() => {
handleClick(selectedRows);
}, [selectedRows]);
最佳答案
我在这里看到很多奇怪和不正确的答案,所以我觉得有必要写这个。
将函数添加到依赖项数组时达到最大调用深度的原因是它没有稳定的标识。在 React 中,如果您不将函数包装在 useCallback
中,则会在每次渲染时重新创建函数。钩。这将导致 react 看到你的函数在每次渲染时都发生了变化,因此每次都会调用你的 useEffect 函数。
一种解决方案是将函数包装在 useCallback
中。它在父组件中定义,并将其添加到子组件中的依赖数组中。使用您的示例,这将是:
const ParentGrid = ({rows, columns}) => {
const [selection, setSelection] = useState(null);
const handleClick = useCallback((selectedRows) => {
setSelection(selectedRows.map(i => rows[i]));
}, [rows]); // setSelection not needed because react guarantees it's stable
return (
<ChildGrid
columns={columns}
data={data}
handleClick={handleClick}
/>
);
}
const ChildGrid = props => {
const {data, handleClick, ...rest} = props;
useEffect(() => {
handleClick(selectedRows);
}, [selectedRows, handleClick]);
};
(这假设父组件中的
rows
Prop 在每次渲染时都不会改变)
关于javascript - 如何在 UseEffect 中使用 prop 函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62464488/
我是一名优秀的程序员,十分优秀!