我在我的项目中遇到无效的钩子调用错误。
<DateBottomSheet
key={keyIndexStartDate}
currentDate={startDate}
headerTitle={moment(startDate).format('MMMM YYYY')}
backdropComponent={renderBackdrop}
ref={sheetRefStartDate}
snapPoints={snapPointsDateSheet}
markedDates={markedStartDate}
onChange={() => handleSheetChanges}
renderArrow={renderCalendarRightAndLeftIcon}
onPressArrowRight={()=>onPressCalendarRight(startDate, 'startDate')}
onPressArrowLeft={()=>onPressCalendarLeft(startDate, 'startDate')}
onDayPress={day => {
setMarkedStartDateValue(day.dateString);
pressOpenStartTimerAction();
// handleSnapPress(1, CreateWorkyBS.startTime);
}}
onPressCancel={() =>
handleCloseStartCalender(CreateWorkyBS.startDate)
}
onPressSave={() => saveStartDateItem()}
saveButtonDisable={buttonStartDateDisable}></DateBottomSheet>
这是我的 OnpressCalendar 功能
const onPressCalendarRight = (date, type) =>
useCallback(add => {
const addDate = moment(date).add(1, 'M');
type == 'startDate' ? setStartDate(addDate) : setEndDate(addDate);
add();
});
有人帮助我吗?
您违反了Hooks 规则。
useCallback
是一个钩子,因此只能在功能组件的根级别调用。
看起来你可以简单地完全删除
useCallback
的使用来解决这个问题,并直接在onPressCalendarRight
中调用嵌入的函数。
const onPressCalendarRight = (date, type) => {
const addDate = moment(date).add(1, 'M');
type == 'startDate' ? setStartDate(addDate) : setEndDate(addDate);
}
试试这个
Const onPressCalendarRight = useCallback((add) => (date,type) => {
const addDate = moment(date).add(1, 'M');
type == 'startDate' ? setStartDate(addDate) : setEndDate(addDate);
add();
},[AddDate]);