2

我在我的项目中使用 react-datepicker。所需格式为 mm/dd/yyyy。我想要的是,如果我想输入一个日期,应该是日期格式。

例如:我想要 1980 年 1 月 21 日的日期。当我从日期选择器中选择时,它的格式正确(01/21/1980)。

现在,如果我输入相同的日期,它不会在两者之间自动插入斜杠,而是显示像 01211980 这样的日期。

<div className="dashboard-patients-details_row_value">
   <Field name="DateRec" component={Datepicker} disabled={isEditing?false:true}/>
</div>

<div className="datepicker">
   <DatePicker
      selected={value ? moment(value) : null}
      onChange={onChange}
      disabled={disabled}
    />
  <div className="calendar-block">
    <CalendarIcon onClick={this.datepicker}
  />
 </div>
</div>

如何解决这个问题?

4

2 回答 2

3

在这种情况下,我们需要稍微自定义这个标签customInput,例如 -

<DatePicker
  customInput={<ExampleCustomInput />}
  selected={value ? moment(value) : null}
  disabled={disabled}
   onChange={onChange}
/>

注意 - 使用您的标签更改标签,您可以使用https://github.com/text-mask/text-mask/tree/master/react/#readme库来屏蔽您的输入,例如 -

<DatePicker
  customInput={<MaskedInput
  mask={['(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, /\d/, /\d/]}
/>}
  selected={value ? moment(value) : null}
  disabled={disabled}
   onChange={onChange}
/>

根据需要更改格式 一切顺利。

于 2019-06-20T05:21:08.370 回答
3

我解决了这个问题。这是我的代码

    import MaskedInput from 'react-text-mask'
import createAutoCorrectedDatePipe from 'text-mask-addons/dist/createAutoCorrectedDatePipe'

const autoCorrectedDatePipe = createAutoCorrectedDatePipe('mm/dd/yyyy HH:MM')
<DatePicker
                    selected={value ? moment(value) : null}
                    onChange={onChange}
                    disabled={disabled}
                    customInput={
                        <MaskedInput
                            pipe={autoCorrectedDatePipe}
                            mask={[/\d/, /\d/, '/', /\d/, /\d/, '/', /\d/, /\d/, /\d/, /\d/]}
                            keepCharPositions= {true}
                            guide = {true}
                        />

                    }
                />
于 2019-06-20T09:43:23.930 回答