Front-end/React

Callback Ref : DOM 참조를 더 유연하게 관리

mooyou 2024. 12. 7. 23:07
728x90
300x250
SMALL

 

앞서 useRef를 활용해 DOM요소를 참조하는 방법을 살펴봤는데 상황에 따라 정적인 참조 방식으로는 해결하기 어려운 문제가 있을 수 있다. 이럴 때 더 동적이고 유연한 방식으로 DOM참조를 관리할 수 있는 Callback Ref가 유용하다.

DOM 요소에 대한 참조를 설정하거나 업데이트 할 때 더 많은 제어권을 가질 수 있다.

 

Callback ref는 React에서 DOM 요소나 컴포넌트의 참조를 관리하는 또 다른 방법으로 useRef와  React.createRef()를 대신해서 사용할 수 있다.

일반적으로 React에서 ref를 사용하면 컴포넌트가 DOM요소를 참조하도록 설정할 수 있지만,

Callback ref는 동적으로 참조를 설정하거나 특정 동작을 할 때 유용하게 사용된다.

 

기본 사용법:

Callback ref는 함수 형태로 ref를 설정하는 방식이다. 이 함수는 React가 해당 요소에 참조를 설정하거나 해제할 때마다 호출된다.

 

문법

function MyComponent() {
  const setRef = (node) => {
    // node는 실제 DOM 요소입니다
    if (node) {
      // ref가 설정되었을 때
      console.log("DOM element is mounted", node);
    } else {
      // ref가 해제되었을 때
      console.log("DOM element is unmounted");
    }
  };

  return <div ref={setRef}>Hello, world!</div>;
}

 

 

1. setRef는 DOM 요소를 받는 콜백 함수 이다.

  • React가 <div>를 DOM에 추가할 때 setRef(node)를 호출하고, node에 해당 DOM요소를 전달한다.
  • React가 <div>를 DOM에서 제거하면 setRef(null)을 호출한다.

2. 선언 없이 ref={setRef}만 설정하면 된다.

  • useRef(null)처럼 값을 미리 저장할 필요가 없다.

 

동작의 흐름 이해

1. 컴포넌트가 처음 렌더링 되면 <div>가 DOM에 추가 되고, setRef가 호출된다.

  • 이때 node는 <div> DOM 요소를 가리킨다.
  • console.log("DOM element is mounted", node)가 실행되어 <div> DOM 요소 정보를 출력한다.

2. 컴포넌트가 언마운트되면 React는 setRef(null)을 호출한다.

  • 이때 node는 null이 되고, console.log("DOM element is unmounted")가 실행된다.

 

주의할 점

callback ref는 React가 ref 설정 시마다 호출된다. 따라서 DOM변경 로직이 자주 실행되면 성능에 영향을 줄 수 있다.

 

 

특징

1. 동적으로 ref를 처리 : setRef함수는 동적으로 DOM 요소에 대한 참조를 설정하고 해제할 수 있다.

node인자는 해당 DOM 요소를 가리키며, 요소가 마운트되면 node에 그 요소가 할당되고, 언마운트되면 node는 null로 설정된다.

2. 리액트의 ref와 유사하지만 더 유연함 : useRef나 React.createRef()는 ref가 한 번 설정되면 계속해서 참조 되지만, callback ref는 참조할 때마다 동적으로 실행되므로 , 참조가 필요할 때마다 특정 작업을 수행하 ㄹ수 있다.

 

 

예시 : DOM 요소 참조와 함께 작업하기

import React, { useState } from 'react';

function FocusableInput() {
  const [focused, setFocused] = useState(false);

  // ref를 설정할 함수 정의
  const inputRef = (node) => {
    if (node) {
      if (focused) {
        node.focus();  // Focused 상태일 때 input에 focus
      } else {
        node.blur();  // 블러 상태일 때 blur
      }
    }
  };

  return (
    <div>
      <input ref={inputRef} />
      <button onClick={() => setFocused(!focused)}>
        Toggle Focus
      </button>
    </div>
  );
}

export default FocusableInput;

 

  • inputRef함수는 ref={inputRef}로 설정되어 있으며, <input /> 요소가 마운트되거나 언마운트될 때마다 호출된다.
  • focused 상태에 따라 inputRef에서 해당 input 요소에 focus() 또는 blur()를 적용한다.
  • 버튼을 클릭하면 focused 값이 변경되고, inputRef함수가 호출되어 해당 input 요소의 포커스를 제어한다.

 

사용하는 이유

  • 동적인 참조 관리 : useRef나 createRef로는 주로 참조가 초기화되며 값이 변하지 않지만, callback ref를 사용하면 동적으로 추가적인 작업을 할 수 있다.
  • 더 정밀한 제어 : 컴포넌트에서 참조를 보다 정밀하게 제어 할 수 있으며, 다른 사이드 이펙트를 처리할 수 있다.

 

정리 

callback ref는 React에서 ref를 함수 형태로 설정하여, DOM 요소에 대해 마운트 및 언마운트 시 동작을 제어 하는 방식이다. 이를 통해 ref가 설정되거나 해제될 때마다 특정 동작을 트리거할 수 있다. useRef나 createRef에 비해 더 유연하고 동적인 사용이 가능하다.

 

 

 

 

728x90
반응형
LIST