在 antd design react 中使用 DatePicker 和 Form FormItem

IT技术 reactjs antd
2021-05-21 21:36:30
    <FormItem {...formItemLayout} label="Publish Date">
      {getFieldDecorator('publishDate', {
        initialValue: '',
        rules: [
          {
            required: false,
            message: 'Please input publishDate',
            whitespace: true,
          },
        ],
      })(<DatePicker onChange={onChange} />)}
    </FormItem>

不起作用。我收到异步验证器说“publishDate 不是字符串”。

所以我以这种方式使用它作为临时解决方案。

<FormItem {...formItemLayout} label="Publish Date">
  {getFieldDecorator('publishDate', {
    initialValue: getCurrentDate(),
    rules: [
      {
        required: false,
        message: 'Please input publishDate',
        whitespace: true,
      },
    ],
  })}
  <DatePicker onChange={onChange} />
</FormItem>

有什么帮助吗?提前致谢!

2个回答

应该type: 'object'在规则中使用

<FormItem {...formItemLayout} label="Publish Date">
  {getFieldDecorator('publishDate', {
    initialValue: moment(),
    rules: [
      {
        type: 'object',
        required: false,
        message: 'Please input publishDate',
        whitespace: true,
      },
    ],
  })(<DatePicker/>)}
</FormItem>

此外,您不需要onChange处理程序。

const makeDateField = Component => ({
  input,
  meta,
  children,
  hasFeedback,
  label,
  labelRight,
  ...rest
}) => {
  /* eslint-disable no-underscore-dangle */
  const hasError = meta.touched && meta.invalid;

  input = {
    ...input,
    value: input.value && input.value._isValid ? moment(input.value) : moment(),

  };
  return (
    <FormItem
      {...formItemLayout}
      label={label}
      validateStatus={hasError ? 'error' : 'success'}
      hasFeedback={hasFeedback && hasError}
      help={hasError && meta.error}
    >
      <Component 
        {...input} 
        {...rest}
        onChange={(event, value) => input.onChange(event)} 
        onBlur={(event, value) => input.onBlur(value) } 
      >
        {children}
      </Component>
      {labelRight && <span style={{ color: '#9e9e9e' }}>{labelRight}</span>}
    </FormItem>
  );
};

export const ADatePicker = makeDateField(DatePicker);

表格中的用法

   <Field
     label="Start Date"
     placeholder="Start Date"
     name="startDate"
     component={ADatePicker}
   />