首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在使用date-fns格式化的react-day-picker输入上输入日期

在使用date-fns格式化的react-day-picker输入上输入日期
EN

Stack Overflow用户
提问于 2019-09-05 02:52:46
回答 1查看 604关注 0票数 0

我不能使用onDayChange使用react-day-picker手动输入日期,但是当我使用onChange时我可以。但是,我没有使用onChange获得所选值,而且我还使用了date-fns来格式化日期。

代码语言:javascript
复制
handleChangeDate(date, value) {
    this.setState({
      [value]: date,
    });
  }

  parseDate(str, format, locale) {
    const parsed = dateFnsParse(str, format, new Date(), { locale });

    if (dateFnsValid(parsed)) {
      return parsed;
    }

    return undefined;
  }

  formatDate(date, format, locale) {
    return dateFnsFormat(date, format, { locale });
  }

使用onDayChange

代码语言:javascript
复制
<DayPickerInput
   placeholder="Date Engaged"
   value={dateEngaged}
   format="dd/MM/yyyy"
   formatDate={this.formatDate}
   parseDate={this.parseDate}
   onDayChange={value => this.handleChangeDate(value, 'dateEngaged')}
  />

使用onChange

代码语言:javascript
复制
<DayPickerInput
   placeholder="Date Engaged"
   value={dateEngaged}
   format="dd/MM/yyyy"
   formatDate={this.formatDate}
   parseDate={this.parseDate}
   onChange={value => this.handleChangeDate(value, 'dateEngaged')}
  />
EN

回答 1

Stack Overflow用户

发布于 2019-09-07 13:16:07

这是他们的文档中有关如何使用handleDayChange的示例

代码语言:javascript
复制
handleDayChange(selectedDay, modifiers, dayPickerInput) {
 const input = dayPickerInput.getInput();
 this.setState({
   selectedDay,
   isEmpty: !input.value.trim(),
   isValidDay: typeof selectedDay !== 'undefined',
   isDisabled: modifiers.disabled === true,
 });
}

 <DayPickerInput onDayChange={handleDayChange}/>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57794304

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档