如何让 React Calendar Range 在第一次呈现时不选择当前日期

问题描述

我正在使用 React 日历 https://www.npmjs.com/package/react-calendar,我想通过单击开始日期和结束日期来选择一个天数范围。我在 Calendar 中使用了 selectRange 道具,但是第一次 Calendar 呈现时,甚至没有点击任何东西,范围选择器将自动将开始日期作为今天的日期。我不想这样。我想以干净的状态加载日历,然后当我开始单击这将是开始日期时,然后我可以单击结束日期的下一个元素。我怎样才能做到这一点?

这是我的代码

export default function TestCalendar() {
    const [value,onChange] = useState(new Date())

    return(
        <>
        <Calendar selectRange={true} onChange={onChange}
        value={value} minDate={new Date()} minDetail={"year"} navigationAriaLabel={"Go up"} activeStartDate={null}/>

        {value[0] != null && <><div>{value[0].toString()}</div><div>{value[1].toString()}</div></>}

        </>
    )
}

这是我不想要的功能示例(加载时它会自动选择今天的日期(6 月 5 日),然后我开始悬停以单击结束日期): https://i.gyazo.com/91ec726a453c2b138f9c1b0aae09e1a6.mp4

解决方法

好吧,我想出了答案。我正在复制入门代码,但我不知道 value 道具也设置了 Beginning 值。如果我从 中删除该道具,那么一切正常,我可以选择开始日期,而不会自动获取当前日期。

,

问题是您将 value 初始化为今天 (new Date()) 并分配给 Calendarvalue 道具。我建议您使用 defaultValue(以不受控制的方式使用 react-calendar)。