Task
I'm trying to use React.forwardRef() and in the same time use React.useRef() in a component.
Problem
I can use either only myOwnRef or ref from forwardRef prop. So, I have no idea how to use them together.
Example code:
interface IExampleInputProps {
value: string,
onChange: (event: ChangeEvent<HTMLInputElement>) => void
}
const ExampleInput = forwardRef<HTMLInputElement | null, IExampleInputProps>(({value, onChange}, ref) => { // can't to use "ref" parameter
const myOwnRef = React.useRef<HTMLInputElement | null>(null);
return <input ref={el => {
myOwnRef.current = el; // => OK
if (ref) { // trying to use the ref passed from the forwardRef function
ref.current = el; // => ERROR
}
}} value={value} onChange={onChange}/>
})
Thanks a lot for your answers.
To access a ref while also forwarding it, it is simpler to do the following:
useImperativeHandlehook on the outer ref (which is being forwarded to) and pass a function that returns thecurrentproperty of the inner ref, which is the value that will be set to thecurrentproperty of the outer ref.