Redux 形式的 DatePicker

IT技术 forms reactjs date redux redux-form
2021-04-19 03:18:52

我想使用 DatePicker 使用 redux 表单选择日期。我创建这个:

import React from 'react';
import DatePicker from 'react-datepicker';
import 'react-datepicker/dist/react-datepicker.css';

export default field => (
  <div>
    <DatePicker
      onChange={field.value}
      selected={field.value}
      isClearable={true}
    >
      {field.children}
    </DatePicker>
    {field.meta.touched && field.meta.error &&
    <span className="error">{field.meta.error}</span>}
  </div>
);
<div className="form-group">
        <div className="col-xs-12 col-sm-3 ">
          <div className="label" htmlFor="date-to">DATE TO</div>{' '}
          <Field
            id="date-to"
            name="date-to"
            component={DateInput}
          />
        </div>
  </div>

但它不返回任何值并且不显示字段中的日期我该怎么办?

3个回答

您想包装 DatePicker 元素,使其可以用作“字段”上的组件,如下所示:

const renderDatePicker = ({input, placeholder, defaultValue, meta: {touched, error} }) => (
  <div>
        <DatePicker {...input} dateForm="MM/DD/YYYY" selected={input.value ? moment(input.value) : null} />
        {touched && error && <span>{error}</span>}
  </div>
);

export default renderDatePicker

有关更多信息,请参阅此 GitHub 问题:https : //github.com/Hacker0x01/react-datepicker/issues/543

就我而言,我使用这种方法获得了一个警告:警告:失败的道具类型:提供给value的类型无效的道具,预计 在 DatePicker 中。所以,我添加了事件 onChange() 来修复它:objectDatePickerstring<DatePicker {...input} dateForm="YYYY/MM/DD" selected={input.value ? moment(input.value) : null} onChange={date => input.onChange(moment(date).format('YYYY/MM/DD'))} />
2021-05-31 03:18:52
export const renderDatePicker = ({ input, label, meta: { touched, error }, ...custom }) => {
    return (
        <DatePicker {...input} {...custom} autoOk={true} dateForm='MM/DD/YYYY' onChange={(event, value) => input.onChange(value)} />
    );
};
默认情况下,要从日期选择器获取值,我们需要执行 2 个步骤。步骤 1:在日期选择器上选择一个日期。第 2 步:单击“确定”按钮以获取该值。
2021-05-26 03:18:52
onChange={(event, value) => input.onChange(value)},这个事件将有助于将数据更新到 redux。
2021-05-29 03:18:52
什么是 autoOk 道具?
2021-05-30 03:18:52
但是如果 autoOk = true,我们只需在日期选择器上选择一个日期,就可以获得新值。
2021-06-19 03:18:52
export const Datepicker = ({

input, id, label, required, className, disabled, intl, popoverAttachment, popoverTargetAttachment, popoverTargetOffset, todayButton,
meta: { touched, error, invalid } }) => (
    <FormGroup color={`${touched && invalid ? 'danger' : ''}`} className={`${required ? 'required ' : ' '}${className}`}>
        {label && <Label htmlFor={id}>{label}</Label>}
        <DatePicker
            className="form-control"
            {...input}
            fixedHeight
            todayButton={todayButton}
            label={label}
            id={id}
            dateForm="MM/DD/YYYY"
            selected={input.value ? moment(input.value) : null}
            disabled={disabled}
            popoverAttachment={popoverAttachment}
            popoverTargetAttachment={popoverTargetAttachment}
            popoverTargetOffset={popoverTargetOffset}
        />
        {touched && error && <FormFeedback>{intl.formatMessage(error)}</FormFeedback>}
    </FormGroup>
);

您可以像我上面提到的那样制作自己的 datepicker 组件字段,并在 Redux 字段中使用它