繁体   English   中英

如何使 React Calendar Range 在首次呈现时不选择当前日期

[英]How to make React Calendar Range NOT select the current date when it first renders

我正在使用 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 值。 如果我从 <Calendar /> 中删除该道具,那么一切正常,我可以选择开始日期而不自动获取当前日期。

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM