我正在react-hook-form
从版本 6.x 升级到 7.x,并且说明说Component
as
用render
道具替换 。
这对我的大多数样式组件都很好,但对我来说,DatePicker
我需要传入一个inputRef
它才能工作。
旧代码(在react-hook-form
v6下运行良好)如下
export const DatePicker = styled(
({ name, validation, label, control, value, onChange, disablePast, ...props }) => (
<Row id={name} {...props}>
<Controller
as={forwardRef((_props, ref) => (
<KeyboardDatePicker
id={name}
name={name}
disableToolbar
margin="dense"
inputVariant="outlined"
format="dd-MM-yyyy"
label={label}
value={value}
onChange={onChange}
autoOk
inputRef={ref}
disablePast={disablePast}
/>
))}
name={name}
control={control}
rules={validation}
/>
</Row>
)
)(({ theme }) => ({
padding: theme.spacing(0, 0, 1, 0)
}))
所以用道具替换as
看起来render
像
export const DatePicker = styled(
({ name, validation, label, control, value, onChange, disablePast, ...props }) => (
<Row id={name} {...props}>
<Controller
render={({ field }) =>
forwardRef((_props, ref) => (
<KeyboardDatePicker
{...field}
id={name}
name={name}
disableToolbar
margin="dense"
inputVariant="outlined"
format="dd-MM-yyyy"
label={label}
value={value}
onChange={onChange}
autoOk
inputRef={ref}
disablePast={disablePast}
/>
))
}
name={name}
control={control}
rules={validation}
/>
</Row>
)
)(({ theme }) => ({
padding: theme.spacing(0, 0, 1, 0)
}))
但这不起作用,我得到了错误
Objects are not valid as a React child (found: object with keys {$$typeof, render})
问题似乎是我的使用,forwardRef
并且尽我所能,我无法弄清楚在哪里或如何解决它。