createRef
createRef
creates a ref object which can contain arbitrary value.
class MyInput extends Component { inputRef = createRef(); // ... }
Reference
createRef()
Call createRef
to declare a ref inside a class component.
import { createRef, Component } from 'react'; class MyComponent extends Component { intervalRef = createRef(); inputRef = createRef(); // ...
Parameters
createRef
takes no parameters.
Returns
createRef
returns an object with a single property:
current
: Initially, it’s set to thenull
. You can later set it to something else. If you pass the ref object to React as aref
attribute to a JSX node, React will set itscurrent
property.
Caveats
createRef
always returns a different object. It’s equivalent to writing{ current: null }
yourself.- In a function component, you probably want
useRef
instead which always returns the same object. const ref = useRef()
is equivalent toconst [ref, _] = useState(() => createRef(null))
.
Usage
Declaring a ref in a class component
To declare a ref inside a class component, call createRef
and assign its result to a class field:
import { Component, createRef } from 'react'; class Form extends Component { inputRef = createRef(); // ... }
If you now pass ref={this.inputRef}
to an <input>
in your JSX, React will populate this.inputRef.current
with the input DOM node. For example, here is how you make a button that focuses the input:
Alternatives
Migrating from a class with createRef
to a function with useRef
We recommend using function components instead of class components in new code. If you have some existing class components using createRef
, here is how you can convert them. This is the original code:
When you convert this component from a class to a function, replace calls to createRef
with calls to useRef
: