Summary of some common uses of refs in React

Summary of some common uses of refs in React

What are Refs

Refs provide a way to allow us to access DOM nodes or React elements created in the render method.
Ref forwarding is a technique that automatically passes refs through components to their children. Tools commonly used to obtain DOM nodes or React element instances. Refs in React provide a way to allow users to access DOM nodes or React elements created in the render method.

Refs

Ref forwarding is an optional feature that allows certain components to receive a ref and pass it down (in other words, "forward" it) to child components.

By default, you cannot use the ref attribute on function components because they don't have instances:

1. String Refs

It is not recommended to use this method because of some issues with string refs. It is deprecated and may be removed in a future version.

import React from "react";
// Parent component export default class StringRef extends React.PureComponent {
  componentDidMount() {
    console.log("stringRefDom:", this.refs.stringRefDom);
    console.log("stringRefComp:", this.refs.stringRefComp);
  }
  render() {
    return (
      <div>
        {/*How to use native components*/}
        <div ref={"stringRefDom"}>stringRefDom</div>
        {/*How to use the class component*/}
        <StringRefComp ref={"stringRefComp"} />
      </div>
    );
  }
}
//Class component class StringRefComp extends React.PureComponent {
  render() {
    return <div>StringRefComp</div>;
  }
}

2. Callback Refs

  • If the ref callback function is defined as an inline function, it will be executed twice during the update process.
  • The first time the parameter is null, the second time the parameter DOM element is passed
  • This is because a new instance of the function is created on each render, so React clears the old ref and sets the new one.
  • The above problem can be avoided by defining the callback function of ref as a bound function of the class.
  • But most of the time it's irrelevant
import React from "react";
// Parent component export default class CallbackRef extends React.PureComponent {
  constructor(props) {
    super(props);
    this.callbackRefDom = null;
    this.callbackRefComp = null;
  }
  componentDidMount() {
    console.log("callbackRefDom:", this.callbackRefDom);
    console.log("callbackRefComp:", this.callbackRefComp);
  }
  //Callback function setCallbackRefDom = (ref) => {
    this.callbackRefDom = ref;
  };
  setCallbackRefComp = (ref) => {
    this.callbackRefComp = ref;
  };
  //Callback function render() {
    return (
      <div>
        <div ref={this.setCallbackRefDom}>callbackRefDom</div>
        <CallbackRefComp ref={this.setCallbackRefComp} />
      </div>
    );
  }
}

//Class component class CallbackRefComp extends React.PureComponent {
  render() {
    return <div>callbackRefComp</div>;
  }
}

React.createRef()

  • React 16.3 introduced
  • In earlier versions of React, callback refs are recommended.
import React from "react";
// Parent component export default class CreateRef extends React.PureComponent {
  constructor(props) {
    super(props);
    this.createRefDom = React.createRef();
    this.createRefComp = React.createRef();
  }
  componentDidMount() {
    console.log("createRefDom:", this.createRefDom.current);
    console.log("createRefComp:", this.createRefComp.current);
  }
  render() {
    return (
      <div>
        <div ref={this.createRefDom}>createRefDom</div>
        <CreateRefComp ref={this.createRefComp} />
      </div>
    );
  }
}
//Class component class CreateRefComp extends React.PureComponent {
  render() {
    return <div>CreateRefComp</div>;
  }
}

4. useRef

  • Hooks are a new feature in React 16.8
import React, { useEffect } from "react";
// Parent component const UseRef = React.memo(() => {
  // // You can also use // const createRefDom = React.createRef();
  // const createRefComp = React.createRef();
  const createRefDom = React.useRef();
  const createRefComp = React.useRef();
  useEffect(() => {
    console.log("useRefDom:", createRefDom.current);
    console.log("useRefComp:", createRefComp.current);
  }, []);
  return (
    <div>
      <div ref={createRefDom}>useRefDom</div>
      <UseRefComp ref={createRefComp} />
    </div>
  );
});

export default UseRef;

//Class component class UseRefComp extends React.PureComponent {
  render() {
    return <div>useRefComp</div>;
  }
}

5. Refs and Function Components

  • By default, you cannot use the ref attribute on function components because they don’t have instances.
  • If you want to use ref in a function component, you can use forwardRef (can be used in conjunction with useImperativeHandle)
  • Or convert the component into a class component.
import React, { useEffect, useImperativeHandle } from "react";

// Parent component const ForwardRef = React.memo(() => {
  const createRefComp = React.useRef();
  const createRefCompMethod = React.useRef();

  useEffect(() => {
    console.log("useRefComp:", createRefComp.current);
    console.log("createRefCompMethod:", createRefCompMethod.current);
    createRefComp.current.reload();
  }, []);
  return (
    <div>
      <ForwardRefFunc ref={createRefComp} />
    </div>
  );
});

export default ForwardRef;

const RefFunc = React.forwardRef((props, ref) => {
  const [name, setName] = React.useState(null);
  const reload = () => {
    console.log("reload");
    setTimeout(() => {
      setName("ForwardRefFunc");
    }, 3000);
  };
  //useImperativeHandle allows you to customize the instance value exposed to the parent component when using refuseImperativeHandle(ref, () => {
    return {
      reload: reload,
    };
  });
  return <div ref={ref}>ForwardRefFunc {name}</div>;
});
const ForwardRefFunc = React.memo(RefFunc);

The ultimate goal of forwardRef and useImperativeHandle is to try to provide a callable object to ref!

  • Refs and the DOM
  • forwardRef
  • UseImperativeHandle

Summarize

This concludes this article about some common uses of refs in React. For more information about the use of refs in React, please search 123WORDPRESS.COM’s previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed explanation of the use of Refs in React's three major attributes
  • An in-depth introduction to React refs
  • Tutorial on using refs in React
  • Detailed explanation of the use of React component refs
  • Do you know the Refs attribute in React?

<<:  How to expand the disk size of a virtual machine

>>:  MySQL 8.0 DDL atomicity feature and implementation principle

Recommend

MySql 8.0.16-win64 Installation Tutorial

1. Unzip the downloaded file as shown below . 2. ...

Detailed tutorial of using stimulsoft.reports.js with vue-cli

vue-cli uses stimulsoft.reports.js (nanny-level t...

MySQL Community Server 5.7.19 Installation Guide (Detailed)

MySQL official website zip file download link htt...

How to solve the front-end cross-domain problem using Nginx proxy

Preface Nginx (pronounced "engine X") i...

Native JS to achieve drag photo wall

This article shares with you a draggable photo wa...

The main idea of ​​​​dynamically setting routing permissions in Vue

I have seen some dynamic routing settings on the ...

Detailed explanation of MySql slow query analysis and opening slow query log

I have also been researching MySQL performance op...

JavaScript Basics: Immediate Execution Function

Table of contents Immediately execute function fo...

Detailed explanation of the practical use of HTML table layout

When is the table used? Nowadays, tables are gene...

Pure JavaScript to implement the number guessing game

Develop a number guessing game that randomly sele...

harborRestart operation after modifying the configuration file

I won't say much nonsense, let's just loo...