Refs
What is the use of refs?
The ref is used to return a reference to the element. They should be avoided in most cases, however, they can be useful when you need a direct access to the DOM element or an instance of a component.
How to create refs?
There are two approaches
- This is a recently added approach. Refs are created using
React.createRef()
method and attached to React elements via theref
attribute. In order to use refs throughout the component, just assign the ref to the instance property within constructor.
- You can also use ref callbacks approach regardless of React version. For example, the search bar component's input element accessed as follows,
You can also use refs in function components using closures. Note: You can also use inline ref callbacks even though it is not a recommended approach
What are forward refs?
Ref forwarding is a feature that lets some components take a ref they receive, and pass it further down to a child.
Which is preferred option with in callback refs and findDOMNode()?
It is preferred to use callback refs over findDOMNode()
API. Because findDOMNode()
prevents certain improvements in React in the future.
The legacy approach of using findDOMNode
:
The recommended approach is:
Why are String Refs legacy?
If you worked with React before, you might be familiar with an older API where the ref
attribute is a string, like ref={'textInput'}
, and the DOM node is accessed as this.refs.textInput
. We advise against it because string refs have below issues, and are considered legacy. String refs were removed in React v16.
- They force React to keep track of currently executing component. This is problematic because it makes react module stateful, and thus causes weird errors when react module is duplicated in the bundle.
- They are not composable โ if a library puts a ref on the passed child, the user can't put another ref on it. Callback refs are perfectly composable.
- They don't work with static analysis like Flow. Flow can't guess the magic that framework does to make the string ref appear on
this.refs
, as well as its type (which could be different). Callback refs are friendlier to static analysis. - It doesn't work as most people would expect with the "render callback" pattern (e.g.
<DataGrid renderRow={this.renderRow} />
)