我将useEffect
与减少动作结合使用。我知道我必须从道具中提取动作函数,并将其作为第二个参数提供,该参数通常适用于批量获取。但是,如果我也使用道具中的ID,它最终会陷入无限循环:
export function EmployeeEdit(props) {
const { fetchOneEmployee } = props;
const id = props.match.params.id;
const [submitErrors, setSubmitErrors] = useState([]);
useEffect(() => fetchOneEmployee(id), [fetchOneEmployee, id]);
const onSubmit = employee => {
employee = prepareValuesForSubmission(employee);
props.updateEmployee(employee._id, employee)
.then( () => props.history.goBack() )
.catch( err => setSubmitErrors(extractErrors(err.response)) );
};
return (
<div>
<h3>Edit Employee</h3>
<NewEmployee employee={props.employee} employees={props.employees} onSubmit={onSubmit} submitErrors={submitErrors} />
</div>
)
}
EmployeeEdit.propTypes = {
fetchOneEmployee: PropTypes.func.isRequired,
employees: PropTypes.array.isRequired,
employee: PropTypes.object.isRequired
};
const mapStateToProps = state => ({
employees: state.employees.items,
employee: state.employees.item
})
export default connect(mapStateToProps, { fetchOneEmployee, updateEmployee })(EmployeeEdit);
还有redux动作:
export const fetchOneEmployee = (id) => dispatch => {
axios.get(`http://localhost:8888/api/users/${id}`)
.then(res => {
const employee = res.data;
dispatch({
type: FETCH_ONE_EMPLOYEE,
payload: employee
})
})
});
};
有人知道我在做什么错吗?
答案 0 :(得分:0)
依赖项数组([fetchOneEmployee, id]
)中的值之一正在更改。用您提供的有限代码很难说出它的价值。
尽管乍一看,您可能希望在阵列中使用fetchOne
而不是fetchOneEmployee
。
答案 1 :(得分:0)
您的inifite循环可能是由于fetchOneEmployee作为useEffect的参数传递引起的。您是否将fetchOneEmployee作为箭头函数传递给EmployeeEdit?如果您这样做了,那么fetchOneEmployee总是会改变的。
这是有关React钩子获取数据的出色文章的一部分。
我特别推荐标题自定义数据抓钩