DEV Community

Cover image for Use Ref in React - the right way
Royal Jain for CodeParrot

Posted on • Originally published at 10xdev.codeparrot.ai

Use Ref in React - the right way

React offers a powerful feature called 'ref.' Understanding how to use ref correctly is essential for React developers. In this article, we will explore the basics of ref, common pitfalls to avoid, and advanced use cases

Basics of Ref in React

What is Ref?

A ref in React provides a way to access the DOM nodes or React elements created in the render method. It's used when you need direct access to a DOM node, for things like managing focus, text selection, or media playback.

Creating Refs

Refs are created using React.createRef() and attached to React elements via the ref attribute. Refs are commonly used in class components, but with the advent of React Hooks, you can also use them in functional components using useRef.

Example in Class Component

class MyComponent extends React.Component {
constructor(props) {
    super(props);
    this.myRef = React.createRef();
}

render() {
    return <div ref={this.myRef} />;
}
}

Enter fullscreen mode Exit fullscreen mode

Example in Functional Component

Accessing Refs

Once assigned to a component, you can access the ref's current property to get the DOM node.

componentDidMount() {
  const node = this.myRef.current;
  // You can now directly access the DOM element.
}
Enter fullscreen mode Exit fullscreen mode

Common Pitfalls and How to Avoid Them

  1. Overusing Refs for Tasks that Should Be Handled by React's State Management

Pitfall: Using refs to manipulate the DOM for tasks like updating the UI, which should ideally be handled by React's state and props.

Example:

class BadExample extends React.Component {
  constructor(props) {
    super(props);
    this.myRef = React.createRef();
  }

  updateText() {
    // Directly manipulating the DOM — not recommended!
    this.myRef.current.textContent = "Updated text!";
  }

  render() {
    return (
      <div>
        <div ref={this.myRef}>Initial text</div>
        <button onClick={() => this.updateText()}>Update Text</button>
      </div>
    );
  }
}

Enter fullscreen mode Exit fullscreen mode

Why It's a Pitfall: This approach bypasses React's state management and rendering lifecycle, potentially leading to unsynchronized states and unpredictable UI behaviours.

  1. Using Refs with Functional Components Incorrectly

Pitfall: Trying to attach refs to functional components without using React.forwardRef.

Example:

function MyFunctionalComponent() {
  return <div>Content</div>;
}

class ParentComponent extends React.Component {
  constructor(props) {
    super(props);
    this.myRef = React.createRef();
  }

  componentDidMount() {
    console.log(this.myRef.current); // Will be null
  }

  render() {
    // Incorrectly trying to attach ref to a functional component
    return <MyFunctionalComponent ref={this.myRef} />;
  }
}

Enter fullscreen mode Exit fullscreen mode

Why It's a Pitfall: Functional components don't have instances, so the ref will be null. It leads to errors or unexpected behaviors.

  1. Updating State on Ref Callbacks

Pitfall: Updating component state within a ref callback, causing potential re-renders or performance issues.

Example:

class BadRefUsage extends React.Component {
  constructor(props) {
    super(props);
    this.state = { height: 0 };
    this.myRef = (element) => {
      if (element) {
        // Incorrectly setting state in a ref callback
        this.setState({ height: element.clientHeight });
      }
    };
  }

  render() {
    return <div ref={this.myRef}>Content</div>;
  }
}

Enter fullscreen mode Exit fullscreen mode

Why It's a Pitfall: The ref callback is not the right place to update the state, as it can be called multiple times before a component mounts and may lead to redundant re-renders or unexpected behaviour.

Use Cases

Integrating with Third-Party DOM Libraries

When integrating with libraries that manipulate the DOM, such as jQuery plugins, refs provide a way to give the library direct access to a DOM node.

componentDidMount() {
  $(this.myRef.current).pluginMethod();
}
Enter fullscreen mode Exit fullscreen mode

Managing Focus, Text Selection, or Media Playback

Refs are ideal for managing focus, text selection, or controlling media playback, as these actions often require direct manipulation of the DOM.

focusTextInput() {
  this.textInput.current.focus();
}
Enter fullscreen mode Exit fullscreen mode

Measuring DOM Node

Sometimes you need to measure a node's size or position. Refs make this straightforward:

measureNode() {
  const dimensions = this.nodeRef.current.getBoundingClientRect();
  // You can now access size and position of the node.
}
Enter fullscreen mode Exit fullscreen mode

Image of Bright Data

Maximize Data Efficiency – Store and process vast amounts efficiently.

Optimize your infrastructure with our solutions designed for high-volume data processing and storage.

Optimize Now

Top comments (0)

Heroku

This site is built on Heroku

Join the ranks of developers at Salesforce, Airbase, DEV, and more who deploy their mission critical applications on Heroku. Sign up today and launch your first app!

Get Started

👋 Kindness is contagious

Discover a treasure trove of wisdom within this insightful piece, highly respected in the nurturing DEV Community enviroment. Developers, whether novice or expert, are encouraged to participate and add to our shared knowledge basin.

A simple "thank you" can illuminate someone's day. Express your appreciation in the comments section!

On DEV, sharing ideas smoothens our journey and strengthens our community ties. Learn something useful? Offering a quick thanks to the author is deeply appreciated.

Okay